savedInstanceState Bundle中的NullPointerException

时间:2014-02-25 06:03:50

标签: java android nullpointerexception bundle oncreate

当我的代码试图访问由Activity类的onSaveInstanceState方法创建的键/值对中的值时,我收到NullPointerException。

我设置了断点,我知道我的Bundle不是null,它包含对我的键/值的引用。我不明白为什么我得到这个运行时错误。这是我的onSaveInstanceState代码

@Override
protected void onSaveInstanceState(Bundle outState) {

    int mPoints = winCount;
    int hPoints = loseCount;
    String reTextView = resultsTextView.getText().toString();
    String pTextView = pointsTextView.getText().toString();
    String roTextView = rollTextView.getText().toString();

    outState.putInt("MY_POINTS", mPoints);
    outState.putInt("HOUSE_POINTS", hPoints);
    outState.putString("RESULTS", reTextView);
    outState.putString("POINTS", pTextView);
    outState.putString("ROLL", roTextView);

    super.onSaveInstanceState(outState);
}

这是我在onCreate方法上恢复状态的代码

// check if app just started or is being restored from memory
      if ( savedInstanceState == null ) // the app just started running
      {
         winCount = 0; 
         loseCount = 0; 
      } 
      else 
      {
         winCount = savedInstanceState.getInt("MY_POINTS");
         loseCount = savedInstanceState.getInt("HOUSE_POINTS");

         resultsTextView.setText(String.valueOf(savedInstanceState.getString("RESULTS")));
         pointsTextView.setText(String.valueOf(savedInstanceState.getString("POINTS")));
         rollTextView.setText(String.valueOf(savedInstanceState.getString("ROLL")));
      } 

我在线上获得了以 resultsTextView.setText ... 开头的运行时错误,这里是在调试模式下从断点检索到的savedInstanceState Bundle的内容

 Bundle[{RESULTS=Roll Again, MY_POINTS=2, POINTS=Your Point is 8,
 HOUSE_POINTS=2,
 android:viewHierarchyState=Bundle[{android:Panels=android.util.SparseArray@421c5560,
 android:views=android.util.SparseArray@421c5358,
 android:ActionBar=android.util.SparseArray@421c57f8}], ROLL=You Rolled
 Easy Four}]

因为你可以看到我的所有字符串都有一个值,有趣的是我没有在int变量(winCount和loseCount)上得到NullPointerException运行时错误,但我得到的是字符串值。我感谢任何帮助。

更新:这是log cat的整个错误日志,我在第68行有 resultsTextView.setText ... (在onCreat()的 else 块内)

 W/dalvikvm(27797): threadid=1: thread exiting with uncaught exception (group=0x418b6700)
E/AndroidRuntime(27797): FATAL EXCEPTION: main
E/AndroidRuntime(27797): java.lang.RuntimeException: Unable to start activity ComponentInfo{…}: java.lang.NullPointerException
E/AndroidRuntime(27797): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2211)
E/AndroidRuntime(27797):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2261)
E/AndroidRuntime(27797):    at android.app.ActivityThread.handleRelaunchActivity(ActivityThread.java:3740)
E/AndroidRuntime(27797):    at android.app.ActivityThread.access$700(ActivityThread.java:141)
E/AndroidRuntime(27797):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1262)
E/AndroidRuntime(27797):    at android.os.Handler.dispatchMessage(Handler.java:99)
E/AndroidRuntime(27797):    at android.os.Looper.loop(Looper.java:137)
E/AndroidRuntime(27797):    at android.app.ActivityThread.main(ActivityThread.java:5103)
E/AndroidRuntime(27797):    at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime(27797):    at java.lang.reflect.Method.invoke(Method.java:525)
E/AndroidRuntime(27797):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
E/AndroidRuntime(27797):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
E/AndroidRuntime(27797):    at dalvik.system.NativeStart.main(Native Method)
E/AndroidRuntime(27797): Caused by: java.lang.NullPointerException
E/AndroidRuntime(27797):    at app.package.onCreate(AppName.java:68)
E/AndroidRuntime(27797):    at android.app.Activity.performCreate(Activity.java:5133)
E/AndroidRuntime(27797):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
E/AndroidRuntime(27797):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2175)
E/AndroidRuntime(27797):    ... 12 more

这是我的整个onCreate方法,因为许多评论员要求查看整个方法。希望它有所帮助!

@Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity);

          // check if app just started or is being restored from memory
          if ( savedInstanceState == null ) // the app just started running
          {
             winCount = 0; 
             loseCount = 0; 
          } 
          else 
          {
             winCount = savedInstanceState.getInt("MY_POINTS");
             loseCount = savedInstanceState.getInt("HOUSE_POINTS");

             resultsTextView.setText(savedInstanceState.getString("RESULTS"));
             pointsTextView.setText(savedInstanceState.getString("POINTS"));
             rollTextView.setText(savedInstanceState.getString("ROLL"));
          } 


        die1 = (ImageView) findViewById(R.id.imageView1);
        die2 = (ImageView) findViewById(R.id.imageView2);
        dealButton = (Button) findViewById(R.id.dealButton);
        resetButton = (Button) findViewById(R.id.resetButton);
        resultsTextView = (TextView) findViewById(R.id.resultsTextView);
        myPointsTextView = (TextView) findViewById(R.id.myPointstTextView);
        housePointsTextView = (TextView) findViewById(R.id.housePointsTextView);
        pointsTextView = (TextView) findViewById(R.id.pointsTextView1);
        rollTextView = (TextView) findViewById(R.id.rollTextView);

        dealButton.setOnClickListener(dealButtonListener);
        resetButton.setOnClickListener(resetButtonLinstener);

        //on shake event
        mSensorManager = (SensorManager) getSystemService(SENSOR_SERVICE);
        mAccelerometer = mSensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);
        mShakeDetector = new ShakeDetector(new OnShakeListener() {

            @Override
            public void onShake() {
               game(rollDice());
            }
        });


        resultsTextView.setTextColor(Color.BLACK);
        myPointsTextView.setText(String.format("%s", winCount));
        housePointsTextView.setText(String.format("%s", loseCount));

    }

1 个答案:

答案 0 :(得分:1)

您应该在调用setText方法之前初始化TextView。所以onCreate应该是这样的:

        setContentView(R.layout.activity);

        die1 = (ImageView) findViewById(R.id.imageView1);
        die2 = (ImageView) findViewById(R.id.imageView2);
        dealButton = (Button) findViewById(R.id.dealButton);
        resetButton = (Button) findViewById(R.id.resetButton);
        resultsTextView = (TextView) findViewById(R.id.resultsTextView);
        myPointsTextView = (TextView) findViewById(R.id.myPointstTextView);
        housePointsTextView = (TextView) findViewById(R.id.housePointsTextView);
        pointsTextView = (TextView) findViewById(R.id.pointsTextView1);
        rollTextView = (TextView) findViewById(R.id.rollTextView);

          // check if app just started or is being restored from memory
          if ( savedInstanceState == null ) // the app just started running
          {
             winCount = 0; 
             loseCount = 0; 
          } 
          else 
          {
             winCount = savedInstanceState.getInt("MY_POINTS");
             loseCount = savedInstanceState.getInt("HOUSE_POINTS");

             resultsTextView.setText(savedInstanceState.getString("RESULTS"));
             pointsTextView.setText(savedInstanceState.getString("POINTS"));
             rollTextView.setText(savedInstanceState.getString("ROLL"));
          } 
...