關於android.view.WindowLeaked的解決方案

雖然是小問題一個,但也困擾了我一段時間,如今記下來,給本身作個備忘,也能夠給其餘人一個參考java

  
  
  
  
  1. 1.01-08 01:49:27.874: ERROR/WindowManager(473): Activity com.photos.MainActivity has leaked window android.widget.ImageButton@43e40d10 that was originally added here    
  2.  2.01-08 01:49:27.874: ERROR/WindowManager(473): android.view.WindowLeaked: Activity com.photos.MainActivity has leaked window android.widget.ImageButton@43e40d10 that was originally added here    
  3.  3.01-08 01:49:27.874: ERROR/WindowManager(473):     at android.view.ViewRoot.<init>(ViewRoot.java:247)    
  4.  4.01-08 01:49:27.874: ERROR/WindowManager(473):     at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:148)    
  5.  5.01-08 01:49:27.874: ERROR/WindowManager(473):     at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:91)    
  6.  6.01-08 01:49:27.874: ERROR/WindowManager(473):     at android.view.Window$LocalWindowManager.addView(Window.java:424)    
  7.  7.01-08 01:49:27.874: ERROR/WindowManager(473):     at android.widget.PopupWindow.invokePopup(PopupWindow.java:828)    
  8.  8.01-08 01:49:27.874: ERROR/WindowManager(473):     at android.widget.PopupWindow.showAtLocation(PopupWindow.java:688)    
  9.  9.01-08 01:49:27.874: ERROR/WindowManager(473):     at com.photos.MainActivity.showCommonPopup(MainActivity.java:256)    
  10.  10.01-08 01:49:27.874: ERROR/WindowManager(473):     at com.photos.MainActivity.access$3(MainActivity.java:255)    
  11.  11.01-08 01:49:27.874: ERROR/WindowManager(473):     at com.photos.MainActivity$2.handleMessage(MainActivity.java:88)    
  12.  12.01-08 01:49:27.874: ERROR/WindowManager(473):     at android.os.Handler.dispatchMessage(Handler.java:99)    
  13.  13.01-08 01:49:27.874: ERROR/WindowManager(473):     at android.os.Looper.loop(Looper.java:123)    
  14.  14.01-08 01:49:27.874: ERROR/WindowManager(473):     at android.app.ActivityThread.main(ActivityThread.java:4627)    
  15.  15.01-08 01:49:27.874: ERROR/WindowManager(473):     at java.lang.reflect.Method.invokeNative(Native Method)    
  16.  16.01-08 01:49:27.874: ERROR/WindowManager(473):     at java.lang.reflect.Method.invoke(Method.java:521)    
  17.  17.01-08 01:49:27.874: ERROR/WindowManager(473):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)    
  18.  18.01-08 01:49:27.874: ERROR/WindowManager(473):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)    
  19.  19.01-08 01:49:27.874: ERROR/WindowManager(473):     at dalvik.system.NativeStart.main(Native Method)   

按字面瞭解,Window Leaked大概就是說一個窗體泄漏了,也就是咱們常說的內存泄漏,爲何窗體會泄漏呢?

產生緣由:
咱們知道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

相關文章
相關標籤/搜索