Android - 空数组。在 Android Studio 模拟器中运行,但在拔下电源时不在真实设备上运行

Android - Null Array. Runs in Android Studio emulator but not on real device when unplugged

我一直在通过我的三星 S7 phone(API 23 和 6.0.1)在 Android Studio 模拟器中测试我的应用程序,它工作正常。当我从我的笔记本电脑上拔下它时,运行 应用程序崩溃了。

我的 logcat 说我正在尝试调用一个空数组...但它不是空的?我不明白为什么当我 运行 应用程序通过 Android Studio 到我的 phone 时一切正常,但是当我 运行 它单独运行时它崩溃了。感谢您的帮助!

这是我的 logcat

FATAL EXCEPTION: main
Process: com.example.abc.def, PID: 28693
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.abc.def/com.example.abc.def.MainActivity}: java.lang.NullPointerException: Attempt to read from null array
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3253)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3349)
at android.app.ActivityThread.access00(ActivityThread.java:221)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1794)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:158)
at android.app.ActivityThread.main(ActivityThread.java:7224)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120)
Caused by: java.lang.NullPointerException: Attempt to read from null array
at com.example.abc.def.MainActivity.onCreate(MainActivity.java:49)
at android.app.Activity.performCreate(Activity.java:6876)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1135)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3206)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3349) 
at android.app.ActivityThread.access00(ActivityThread.java:221) 
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1794) 
at android.os.Handler.dispatchMessage(Handler.java:102) 
at android.os.Looper.loop(Looper.java:158) 
at android.app.ActivityThread.main(ActivityThread.java:7224) 
at java.lang.reflect.Method.invoke(Native Method) 
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120) 

这是我的代码。当我调用 btn1.setText(itemArray[0]) 时,问题出现在底部,因为数组是 "null"

public class MainActivity extends AppCompatActivity {

Button btn1, btn2;
String btn1Name, btn2Name;
String btnValue = "", itemValue = "", itemPosition = "";
String[] buttonArray = new String[]{"blank", "blank"};
String[] itemArray = new String[]{"blank", "blank"};
String[] positionArray = new String[]{"blank", "blank"};  

@Override
    protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    btn1 = (Button) findViewById(R.id.button1);
    btn2 = (Button) findViewById(R.id.button2);

    Bundle extras = getIntent().getExtras();
    if (extras != null) {
        btnValue = extras.getString("btnValue");
        itemValue = extras.getString("itemValue");
        itemPosition = extras.getString("itemPosition");

        buttonArray = extras.getStringArray("buttonArray");
        itemArray = extras.getStringArray("array");
        positionArray = extras.getStringArray("positionArray");

        if (btnValue != null && btnValue.equals("btn1")){
            buttonArray[0] = btnValue;
            itemArray[0] = itemValue;
            positionArray[0] = itemPosition;
        } else if (btnValue != null && btnValue.equals("btn2")) {
            buttonArray[1] = btnValue;
            itemArray[1] = itemValue;
            positionArray[1] = itemPosition;
        }
    }

    btn1.setText(itemArray[0]);
    btn2.setText(itemArray[1]);
}
}

我在这里猜测,但是 MainActivity 是项目中的第一个 activity 吗?

我认为您编写了代码来处理返回此 activity 以及来自其他活动的数据。我刚刚尝试 getIntent().getExtras() returns null 当 activity 首次在模拟器上创建时。 但是,当我 运行 它在我的设备上时,getIntent 生成了这个异常。

请注意 onCreate 被调用一次,因此如果您想查看另一个 activity 的结果,请查看 How to manage `startActivityForResult` on Android?