java - onDestroy() 方法上出现 NullPointerException

标签 java android nullpointerexception

我在退出应用程序时遇到此问题:当您单击“返回”按钮时,会出现 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 为空,则程序不会销毁不存在的东西

关于java - onDestroy() 方法上出现 NullPointerException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19786658/

相关文章:

java - 在代码中编译,没有得到我想要的行为。

Java:使用正则表达式解析dxf文件

Android:BroadcastReceiver 时间限制

java - Exoplayer 视频帧在 api<23 的暂停状态下向前移动

android - 使用 MockContentResolver 的查询导致 NullPointerException

java - NullPointerException 的问题

java - 编写一个循环 1 到 100 因数的程序。当它达到有九个因数的数字时应该停止

java - 使用哪种 Android 数据存储技术?

android - 异步任务并从 url NullPointerException 解析 JSONObject

java - 什么是NullPointerException,我该如何解决?