Java onDestroy()方法上的NullPointerException

Java onDestroy()方法上的NullPointerException,java,android,nullpointerexception,Java,Android,Nullpointerexception,我在退出我的应用程序时遇到了这个问题:当你单击“后退”按钮时,将显示LeadBolt ExitAd。然后单击“否”,应用程序退出,toast显示“此应用程序已停止” 所以,这里有一些与广告有关的内容,或者是将MediaPlayer设置为null 代码如下所示: alarm = new MediaPlayer(); ... @Override public void onPause() { super.onPause(); if (alarm !=

我在退出我的应用程序时遇到了这个问题:当你单击“后退”按钮时,将显示LeadBolt ExitAd。然后单击“否”,应用程序退出,toast显示“此应用程序已停止”

所以,这里有一些与广告有关的内容,或者是将MediaPlayer设置为null

代码如下所示:

alarm = new MediaPlayer();
...     
@Override
    public void onPause() {
        super.onPause();
        if (alarm != null) {
            alarm.release();
            alarm = null;
        }

    }

    @Override
    public void onStop() {
        super.onStop();
        if (alarm != null) {
            alarm.release();
            alarm = null;
        }

    }

    public void onDestroy() {
        myController.destroyAd();
//      myController2.destroyAd();
        if (adView != null) {
              adView.destroy();
            }
        super.onDestroy();
        if (alarm != null) {
            alarm.release();
            alarm = null;
        }
    }
异常日志:

11-05 11:06:49.130: E/AndroidRuntime(2019): FATAL EXCEPTION: main
11-05 11:06:49.130: E/AndroidRuntime(2019): java.lang.RuntimeException: Unable to destroy activity {com.klangstudios.car_pilot_remote/com.my_company.my_app.MainActivity}: java.lang.NullPointerException
11-05 11:06:49.130: E/AndroidRuntime(2019):     at android.app.ActivityThread.performDestroyActivity(ActivityThread.java:3451)
11-05 11:06:49.130: E/AndroidRuntime(2019):     at android.app.ActivityThread.handleDestroyActivity(ActivityThread.java:3469)
11-05 11:06:49.130: E/AndroidRuntime(2019):     at android.app.ActivityThread.access$1200(ActivityThread.java:141)
11-05 11:06:49.130: E/AndroidRuntime(2019):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1287)
11-05 11:06:49.130: E/AndroidRuntime(2019):     at android.os.Handler.dispatchMessage(Handler.java:99)
11-05 11:06:49.130: E/AndroidRuntime(2019):     at android.os.Looper.loop(Looper.java:137)
11-05 11:06:49.130: E/AndroidRuntime(2019):     at android.app.ActivityThread.main(ActivityThread.java:5041)
11-05 11:06:49.130: E/AndroidRuntime(2019):     at java.lang.reflect.Method.invokeNative(Native Method)
11-05 11:06:49.130: E/AndroidRuntime(2019):     at java.lang.reflect.Method.invoke(Method.java:511)
11-05 11:06:49.130: E/AndroidRuntime(2019):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
11-05 11:06:49.130: E/AndroidRuntime(2019):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
11-05 11:06:49.130: E/AndroidRuntime(2019):     at dalvik.system.NativeStart.main(Native Method)
11-05 11:06:49.130: E/AndroidRuntime(2019): Caused by: java.lang.NullPointerException
11-05 11:06:49.130: E/AndroidRuntime(2019):     at com.klangstudios.car_pilot_remote.MainActivity.onDestroy(MainActivity.java:209)
11-05 11:06:49.130: E/AndroidRuntime(2019):     at android.app.Activity.performDestroy(Activity.java:5273)
11-05 11:06:49.130: E/AndroidRuntime(2019):     at android.app.Instrumentation.callActivityOnDestroy(Instrumentation.java:1110)
11-05 11:06:49.130: E/AndroidRuntime(2019):     at android.app.ActivityThread.performDestroyActivity(ActivityThread.java:3438)
11-05 11:06:49.130: E/AndroidRuntime(2019):     ... 11 more

有人遇到类似问题吗?


在代码中,您应该替换以下内容:

    myController.destroyAd();
为此:

 if(myController!= null) {
      myController.destroyAd();
}

那就试试吧。您将避免得到空指针异常,因为如果myController为空,那么程序将不会破坏不存在的东西

对我来说,myController似乎为空,是吗?请告诉我这是哪一行:在com.klangstudios.car\u pilot\u remote.MainActivity.onDestroy(MainActivity.java:209)?你确定super.ondestroy()在正确的位置吗?是的,如果它不是
null
(你对
alarm
adView
)执行此检查,那么这是唯一一个不需要事先检查就可以访问的内容。当堆栈跟踪告诉你问题所在的行时,请记住我们看不到行号。为了清楚起见,请您指出NPE实际发生在哪一行?等等,这是有效的!我现在没有收到任何致命错误,只是在LogCat中我发现:E/webview(10281):Error:webview.destroy()在仍然连接时被调用!但这没什么害处。谢谢我很震惊,因为LeadBolt实施指南没有包括任何检查。我的crashlytics应用程序告诉我,现在第210行出现了问题,所以事情和以前一样。区别在于用户不会受到影响,这是一件好事。不过,也许我们可以对此做些什么,这样就不会出现错误:)