带有 Intent 的空对象引用

Mal*_*lik 6 java android android-intent android-activity

所以谢谢给定的任何 awnsers :)
我的问题的解决方案是,我的线路

Intent i = getIntent();
Run Code Online (Sandbox Code Playgroud)

不在我的 onCreate() 函数中。
谢谢你,祝你有美好的一天。






我知道,这种问题在互联网上被问了很多,但我找不到任何对我有帮助的答案,所以我将把我的特例带到这里。

这是我在 MainActivity 中的函数,我在其中创建 Intent 并开始我的第二个活动:

private void showArticle(String entryUrl, String entryTitle) {
    Intent intent = new Intent(this, ArticleActivity.class);
    intent.putExtra(EXTRA_URL, entryUrl.toString());
    intent.putExtra(EXTRA_TITLE, entryTitle.toString());
    Log.d("DEBUG", intent.getStringExtra(EXTRA_URL));
    Log.d("DEBUG", intent.getStringExtra(EXTRA_TITLE));
    Log.d("DEBUG", "EXTRAS PUTTED");
    startActivity(intent);
    Log.d("DEBUG", "ACTIVITY STARTED");
}
Run Code Online (Sandbox Code Playgroud)

这是控制台输出:

01-02 15:29:21.808 7108-7108/com.example.myfirstapp D/DEBUG: http://example.com/correct-url
01-02 15:29:21.809 7108-7108/com.example.myfirstapp D/DEBUG: Yeah, we have the correct title hhere
01-02 15:29:21.809 7108-7108/com.example.myfirstapp D/DEBUG: EXTRAS PUTTED
01-02 15:29:21.809 7108-7108/com.example.myfirstapp I/Timeline: Timeline: Activity_launch_request id:com.example.myfirstapp time:1404863384
01-02 15:29:21.815 7108-7108/com.example.myfirstapp D/DEBUG: ACTIVITY STARTED
Run Code Online (Sandbox Code Playgroud)



Sooo...'直到这里一切正常。然后,谁猜到了,我的第二个活动开始了:

Intent i = getIntent();

...

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_article);
    getActionBar().setDisplayHomeAsUpEnabled(true);
    if (i.getStringExtra(MainActivity.EXTRA_TITLE) == null) {
        setTitle("MEEP");
    } else {
        setTitle(i.getStringExtra(MainActivity.EXTRA_TITLE));
    }

    ...
Run Code Online (Sandbox Code Playgroud)

但是现在我的应用程序崩溃并显示此错误消息:

01-02 15:29:21.855 7108-7108/com.example.myfirstapp D/AndroidRuntime: Shutting down VM
01-02 15:29:21.870 7108-7108/com.example.myfirstapp E/AndroidRuntime:
        FATAL EXCEPTION: main
        Process: com.example.myfirstapp, PID: 7108
        java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.myfirstapp/com.example.myfirstapp.article.ArticleActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String android.content.Intent.getStringExtra(java.lang.String)' on a null object reference
          at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2379)
          at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2442)
          at android.app.ActivityThread.access$800(ActivityThread.java:156)
          at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1351)
          at android.os.Handler.dispatchMessage(Handler.java:102)
          at android.os.Looper.loop(Looper.java:211)
          at android.app.ActivityThread.main(ActivityThread.java:5373)
          at java.lang.reflect.Method.invoke(Native Method)
          at java.lang.reflect.Method.invoke(Method.java:372)
          at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1020)
          at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:815)
        Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String android.content.Intent.getStringExtra(java.lang.String)' on a null object reference
          at com.example.myfirstapp.article.ArticleActivity.onCreate(ArticleActivity.java:44)
          at android.app.Activity.performCreate(Activity.java:5990)
          at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1106)
          at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2332)
          at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2442) 
          at android.app.ActivityThread.access$800(ActivityThread.java:156) 
          at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1351) 
          at android.os.Handler.dispatchMessage(Handler.java:102) 
          at android.os.Looper.loop(Looper.java:211) 
          at android.app.ActivityThread.main(ActivityThread.java:5373) 
          at java.lang.reflect.Method.invoke(Native Method) 
          at java.lang.reflect.Method.invoke(Method.java:372) 
          at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1020) 
          at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:815)
Run Code Online (Sandbox Code Playgroud)




现在我的问题是:为什么我得到一个空指针?我的意思是,日志清楚地显示了额外的内容,为什么我的第二个活动没有收到关键值?任何人都可以帮忙吗?
并且感谢每个提示。

有关更多信息,只需写评论:)

小智 5

你在第二项活动中的“i”是什么?意图?如果此意图是您对主活动的期望,那么如果您的活动带有 SIngleTop 标志,则应将此代码放入 onNewIntent() 中,并且应覆盖此 onNewIntent() 。

在 onCreate() 中,要获得此意图,您应该执行以下操作

Intent i = getIntent()
Run Code Online (Sandbox Code Playgroud)