2011-07-10 36 views
1

我知道这不能是我认为这是困难的。我确信我拥有我可以设想实现我的onClickListener的所有内容。我错过了什么,为什么这个力量会关闭?我已经提供了堆栈来看看。任何帮助都会很棒。这被认为是保存用户设置的简单活动。如果我注释掉这些代码,活动将显示活动。setOnPreferenceClickListener帮助,Forclosing当活动启动

Preference customPref = (Preference) findPreference("customPref"); 

customPref.setOnPreferenceClickListener(new OnPreferenceClickListener() { //this line forcecloses every time i run the activity. 
    @Override 
    public boolean onPreferenceClick(Preference preference) { 
     Toast.makeText(getBaseContext(), 
         "The custom preference has been clicked", 
         Toast.LENGTH_LONG) 
      .show(); 
     SharedPreferences customSharedPreference = getSharedPreferences(
       "myCustomSharedPrefs", Activity.MODE_PRIVATE); 
     SharedPreferences.Editor editor = customSharedPreference.edit(); 
     editor.putString("myCustomPref", "The preference has been clicked"); 
     editor.commit(); 
     return true; 
    } 
}); 

日志:

07-10 16:36:47.137: WARN/System.err(1042): java.lang.NullPointerException 
07-10 16:36:47.147: WARN/System.err(1042):  at com.nyneaxis.android.mpg.Preferences.onCreate(Preferences.java:22) 
07-10 16:36:47.147: WARN/System.err(1042):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
07-10 16:36:47.157: WARN/System.err(1042):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2459) 
07-10 16:36:47.157: WARN/System.err(1042):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2512) 
07-10 16:36:47.157: WARN/System.err(1042):  at android.app.ActivityThread.access$2200(ActivityThread.java:119) 
07-10 16:36:47.157: WARN/System.err(1042):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1863) 
07-10 16:36:47.167: WARN/System.err(1042):  at android.os.Handler.dispatchMessage(Handler.java:99) 
07-10 16:36:47.167: WARN/System.err(1042):  at android.os.Looper.loop(Looper.java:123) 
07-10 16:36:47.167: WARN/System.err(1042):  at android.app.ActivityThread.main(ActivityThread.java:4363) 
07-10 16:36:47.167: WARN/System.err(1042):  at java.lang.reflect.Method.invokeNative(Native Method) 
07-10 16:36:47.177: WARN/System.err(1042):  at java.lang.reflect.Method.invoke(Method.java:521) 
07-10 16:36:47.177: WARN/System.err(1042):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860) 
07-10 16:36:47.177: WARN/System.err(1042):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618) 
07-10 16:36:47.177: WARN/System.err(1042):  at dalvik.system.NativeStart.main(Native Method) 
+0

看起来像'findPreference(“customPref”)'返回'null'。你能检查一下吗? –

回答

4

它看起来像你的customPref变量为空。确保您在偏好xml中使用了customPref的偏好设置(如果使用的话),或者您可能在那里拼错了密钥。

+0

看到我知道这很简单。 –