2011-08-16 16 views
0

オプションメニューからユーザが「ログアウト」(R.Id.logout)を選択するたびにヌルポインタ例外が発生する。私が何を初期化していないのか分かりません。共有環境設定をクリアするとヌルポインタ例外が発生する

@Override 
     public boolean onOptionsItemSelected(MenuItem item) 
     { 
      switch (item.getItemId()) 
      { 
       case R.id.settings:    
        return false; 
       case R.id.about: 
        this.startActivity(new Intent(this, About.class)); 
        return true; 
       case R.id.logout: 
        AlertDialog.Builder alertbox = new AlertDialog.Builder(this); 
        alertbox.setTitle("Logout"); 
        alertbox.setMessage("Logging out will remove your credentials from this phone. \nDo you want to logout?"); 
        alertbox.setPositiveButton("Yes", new DialogInterface.OnClickListener() 
        {     
         public void onClick(DialogInterface dialog, int id) 
         { 
          Editor e = loginPref.edit(); 
          e.clear(); 

          Homepage.this.startActivity(new Intent(getApplicationContext(), Login.class)); 
          Homepage.this.finish();    
         } 
        }); 
        alertbox.setNegativeButton("No", new DialogInterface.OnClickListener() 
        {     
         public void onClick(DialogInterface dialog, int id) 
         { 
          dialog.cancel();      
         } 
        }); 
        AlertDialog alert = alertbox.show(); 
        return true; 
      } 
      return false; 
     } 

logCat

08-16 10:09:49.705: ERROR/AndroidRuntime(1531): FATAL EXCEPTION: main 
08-16 10:09:49.705: ERROR/AndroidRuntime(1531): java.lang.NullPointerException 
08-16 10:09:49.705: ERROR/AndroidRuntime(1531):  at org.*****.android.Homepage$1.onClick(Homepage.java:79) 
08-16 10:09:49.705: ERROR/AndroidRuntime(1531):  at com.android.internal.app.AlertController$ButtonHandler.handleMessage(AlertController.java:158) 
08-16 10:09:49.705: ERROR/AndroidRuntime(1531):  at android.os.Handler.dispatchMessage(Handler.java:99) 
08-16 10:09:49.705: ERROR/AndroidRuntime(1531):  at android.os.Looper.loop(Looper.java:123) 
08-16 10:09:49.705: ERROR/AndroidRuntime(1531):  at android.app.ActivityThread.main(ActivityThread.java:4627) 
08-16 10:09:49.705: ERROR/AndroidRuntime(1531):  at java.lang.reflect.Method.invokeNative(Native Method) 
08-16 10:09:49.705: ERROR/AndroidRuntime(1531):  at java.lang.reflect.Method.invoke(Method.java:521) 
08-16 10:09:49.705: ERROR/AndroidRuntime(1531):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868) 
08-16 10:09:49.705: ERROR/AndroidRuntime(1531):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626) 
08-16 10:09:49.705: ERROR/AndroidRuntime(1531):  at dalvik.system.NativeStart.main(Native Method) 
+0

あなたはlogcatエラーの詳細を表示できますか?nullポインタ例外が発生する場所を知るか、logcatをチェックしてその行にコメントを付けてください – Pratik

+0

どこをクリアしていますか?いくつかのコードとlogcatを投稿してください。 – ngesh

+0

あなたはlogcatを表示することができます... –

答えて

0

それは非常に簡単です。 Homepage.javaの79行目の何かがnullです。これが何行目であるかを確認してください。パッケージ名などの完全なコードを投稿してください。実際にはnullが実際に推測できるので、実際に助けてください。

私の最初の推測がでloginPrefされるだろう:

Editor e = loginPref.edit(); 

あなたはloginPrefを初期化することがありますか?

+0

これは問題だったloginPref = getSharedPreferences(PREFS_NAME、0); – JonWells

関連する問題