之前遇到webview空指針問題,調查了一下源碼,追述到webviewCore
原來在webview執行destory之後,webviewCore會被置為null,而這時候我們的webview仍然沒有任何的跡象,所以我們仍然大膽地使用webview,在執行到loadUrl或者stopLoading等方法時,由於webviewCore已經為null,這時就產生了空指針,異常信息如下:
- 03-01 10:58:21.117: E/AndroidRuntime(13295): java.lang.NullPointerException
- 03-01 10:58:21.117: E/AndroidRuntime(13295): at android.webkit.WebView.stopLoading(WebView.java:2202)
- 03-01 10:58:21.117: E/AndroidRuntime(13295): at com.tiantianmini.android.browser.ui.download.DownloadListener.onDownloadStart(DownloadListener.java:119)
- 03-01 10:58:21.117: E/AndroidRuntime(13295): at android.webkit.CallbackProxy.handleMessage(CallbackProxy.java:405)
- 03-01 10:58:21.117: E/AndroidRuntime(13295): at android.os.Handler.dispatchMessage(Handler.java:99)
- 03-01 10:58:21.117: E/AndroidRuntime(13295): at android.os.Looper.loop(Looper.java:137)
- 03-01 10:58:21.117: E/AndroidRuntime(13295): at android.app.ActivityThread.main(ActivityThread.java:4340)
- 03-01 10:58:21.117: E/AndroidRuntime(13295): at java.lang.reflect.Method.invokeNative(Native Method)
- 03-01 10:58:21.117: E/AndroidRuntime(13295): at java.lang.reflect.Method.invoke(Method.java:511)
- 03-01 10:58:21.117: E/AndroidRuntime(13295): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
- 03-01 10:58:21.117: E/AndroidRuntime(13295): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
- 03-01 10:58:21.117: E/AndroidRuntime(13295): at dalvik.system.NativeStart.main(Native Method)
為了避免該問題,我們有兩種途徑:
1.使用類似loadUrl等方法時,捕獲異常信息
2.自定義類繼承webview,當調用webview的destory方法之後,使用變量保存destroy的狀態,在用到類似loadUrl方法之前判斷是否已經destroy
代碼類似於
更多Android相關信息見Android 專題頁面 http://www.linuxidc.com/topicnews.aspx?tid=11