安卓:MapView上的奇怪npe onDestroy在一个活动中



我在活动中使用mapview,但我收到了一个奇怪的空指针异常,我似乎无法确定原因。

xml:

<com.google.android.gms.maps.MapView
                    xmlns:map="http://schemas.android.com/apk/res-auto"
                    android:id="@+id/myMapView"
                    android:layout_width="match_parent"
                    android:layout_height="156dp"
                    map:cameraZoom="16"
                    map:liteMode="true"
                    android:visibility="invisible"
                    />

然后在活动内部:

private MapView mMapView;

onCreate:中的初始化

mMapView = (MapView) findViewById(R.id.myMapView);

并覆盖方法:

mMapView.onCreate(savedInstanceState);
@Override
protected void onDestroy() {
    super.onDestroy();
    mMapView.onDestroy();
}

@Override
public void onLowMemory() {
    super.onLowMemory();
    mMapView.onLowMemory();
}

@Override
protected void onPause() {
    super.onPause();
    mMapView.onPause();
}

@Override
protected void onResume() {
    super.onResume();
    mMapView.onResume();

}

我不断收到mapview on Destroy方法的崩溃,其堆栈竞争如下:

java.lang.RuntimeException: Unable to destroy activity {myActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'boolean java.util.LinkedList.isEmpty()' on a null object reference
                                                                           at android.app.ActivityThread.performDestroyActivity(ActivityThread.java:3831)
                                                                           at android.app.ActivityThread.handleDestroyActivity(ActivityThread.java:3849)
                                                                           at android.app.ActivityThread.-wrap5(ActivityThread.java)
                                                                           at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1398)
                                                                           at android.os.Handler.dispatchMessage(Handler.java:102)
                                                                           at android.os.Looper.loop(Looper.java:148)
                                                                           at android.app.ActivityThread.main(ActivityThread.java:5417)
                                                                           at java.lang.reflect.Method.invoke(Native Method)
                                                                           at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
                                                                           at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
                                                                        Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'boolean java.util.LinkedList.isEmpty()' on a null object reference
                                                                           at com.google.android.gms.dynamic.zza.zzeJ(Unknown Source)
                                                                           at com.google.android.gms.dynamic.zza.onDestroy(Unknown Source)
                                                                           at com.google.android.gms.maps.MapView.onDestroy(Unknown Source)
                                                                           at myActivity.onDestroy(myActivity.java:454)
                                                                           at android.app.Activity.performDestroy(Activity.java:6422)
                                                                           at android.app.Instrumentation.callActivityOnDestroy(Instrumentation.java:1142)
                                                                           at android.app.ActivityThread.performDestroyActivity(ActivityThread.java:3818)
                                                                           at android.app.ActivityThread.handleDestroyActivity(ActivityThread.java:3849) 
                                                                           at android.app.ActivityThread.-wrap5(ActivityThread.java) 
                                                                           at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1398) 
                                                                           at android.os.Handler.dispatchMessage(Handler.java:102) 
                                                                           at android.os.Looper.loop(Looper.java:148) 
                                                                           at android.app.ActivityThread.main(ActivityThread.java:5417) 
                                                                           at java.lang.reflect.Method.invoke(Native Method) 
                                                                           at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) 
                                                                           at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) 

假设mmapview是在onCreate开始时从xml初始化的,并且一直存在到onDestroy,那么这个空指针的原因是什么?

最后发现原因是我在一个没有执行的if语句中有mapview.oncreate。当我把它移到oncreate方法的一开始,错误就停止了occuring。

如果你确定在onDestroy()之前一切正常,我建议这样做,

@Override
protected void onDestroy() {
    if(mMapView != null) {
        mMapView.onDestroy();
    }
    super.onDestroy();
}

我认为您不必担心在视图中调用onDestroy()。我可能错了,但当活动作为XML视图被破坏时,无论如何都应该这样做。

如果您在onCreate()上初始化了其他对象(适配器或演示者),那么清理它们可能是个好主意(调用释放方法/将它们设置为null或任何需要的)

除此之外,我遵循的一条好规则是暂停/摧毁Shree Krishna的建议:清理你的资源,然后呼叫super。

@Override
    protected void onPause() {
        // clean up your resources in respect to your onResume
        ...
        super.onPause();
    }
@Override
protected void onDestroy() {
    // clean up your resources in respect of onCreate
    ...
    super.onDestroy();
}

相关内容

最新更新