標籤:android windowleaked 異常
問題雖小,不過不知道還是比較麻煩的。異常資訊:
10-22 10:19:38.651 12723-12723/cn.com.zte.uc E/WindowManager﹕ android.view.WindowLeaked: Activity cn.com.zte.uc.activites.shipTicket.OrderWrite1 has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView{423fee70 V.E..... R......D 0,0-455,230} that was originally added here at android.view.ViewRootImpl.<init>(ViewRootImpl.java:364) at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:258) at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:69) at android.app.Dialog.show(Dialog.java:289) at cn.com.zte.uc.activites.BaseActivity.showInProgress(BaseActivity.java:147) at cn.com.zte.uc.activites.shipTicket.OrderWrite1.onClick(OrderWrite1.java:135) at android.view.View.performClick(View.java:4446) at android.view.View$PerformClick.run(View.java:18485) at android.os.Handler.handleCallback(Handler.java:733) at android.os.Handler.dispatchMessage(Handler.java:95) at android.os.Looper.loop(Looper.java:136) at android.app.ActivityThread.main(ActivityThread.java:5262) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:515) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:851) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:667) at dalvik.system.NativeStart.main(Native Method)
直接從項目裡面拷貝出來的,出錯代碼為show一個ProgressDialog。還有一種情況就是ProgressDialog還在顯示的時候,finish activity也會出現。
原因分析:
Android的每一個Activity都有個WindowManager表單管理器,同樣,構建在某個Activity之上的對話方塊、PopupWindow也有相應的WindowManager表單管理器。因為對話方塊、PopupWindown不能脫離Activity而單獨存在著,所以當某個Dialog或者某個PopupWindow正在顯示的時候我們去finish()了承載該Dialog(或PopupWindow)的Activity時,就會拋Window Leaked異常了,因為這個Dialog(或PopupWindow)的WindowManager已經沒有誰可以附屬了,所以它的表單管理器已經泄漏了。
解決辦法:
關閉(finish)某個Activity前,要確保附屬在上面的Dialog或PopupWindow已經關閉(dismiss)了。
【Android】常見異常 —— android.view.WindowLeaked 分析以及解決辦法