從窗口泄漏談android:configChanges屬性


今天有幸去哥們的大公司做了半天的暫時工,一個偶現的Bug折騰了他好久,好不easy今天抓到了異常Log日志。大致的意思就是android.view.windowleaked——窗口泄漏。我在網上查了資料:

Android的每個Activity都有個WindowManager窗口管理器,構建在某個Activity之上的對話框、PopupWindow也有對應的WindowManager窗口管理器。由於Dialog、PopupWindown不能脫離Activity而單獨存在着,所以當承載某個Dialog或者某個PopupWindow正在顯示的Activity被finish()后。而Dialog(或PopupWindow)沒有正常退出的話,就會拋Window Leaked錯誤了,由於這個Dialog(或PopupWindow)的WindowManager已經沒有誰能夠附屬了,所以它的窗口管理器就泄漏了。

依據此信息分析出,在進入新的Activity時突然轉屏(哥們開發的sdk支持橫豎屏切換)。由於在AndroidManifest.xml中沒有配置android:configChanges屬性,此時Activity會又一次調用onCreate方法,即會又一次調用整個生命周期。而此時的Dialog已經顯示並沒有dismiss。所以造成了窗口泄漏。解決辦法就變得如此簡單,在AndroidManifest.xml中配置android:configChanges屬性,這樣當我們橫豎屏切換的時候會調用Activity的onConfigurationChanged方法,不會又一次調用整個生命周期了。

我們最后配置了android:configChanges="screenSize|orientation|keyboardHidden|navigation"。


既然談到了android:configChanges屬性,我又做了進一步的研究,綜合網上的資料,總結出:

1、不設置Activity的android:configChanges時。切屏會又一次調用整個生命周期,切橫屏時會運行一次,切豎屏時會運行兩次

2、設置Activity的android:configChanges="orientation"時,切屏還是會又一次調用整個生命周期,切橫、豎屏時僅僅會運行一次

3、設置Activity的android:configChanges="orientation|keyboardHidden"時,切屏不會又一次調用整個生命周期,僅僅會運行onConfigurationChanged方法

可是。自從Android 3.2(API 13),在設置Activity的android:configChanges="orientation|keyboardHidden"后。還是一樣會又一次調用各個生命周期的。由於screensize也開始跟着設備的橫豎切換而改變。所以在AndroidManifest.xml里設置的MiniSdkVersion和 TargetSdkVersion屬性大於等於13的情況下,假設你想阻止程序在執行時又一次載入Activity,除了設置"orientation"。 你還必須設置" screenSize"。

——以上信息從網上看到,認為非常實用,但自己並沒有驗證過,只是相信也是LZ驗證過發出的,應該會非常實用的。

附上android:configChanges屬性解釋:

VALUE                         DESCRIPTION                                                                                                                                                                                      
"mcc" 國際移動用戶識別碼所屬國家代號是改變了-----  sim被偵測到了,去更新mcc    mcc是移動用戶所屬國家代號
"mnc" 國際移動用戶識別碼的移動網號碼是改變了------ sim被偵測到了。去更新mnc    MNC是移動網號碼,最多由兩位數字組成。用於識別移動用戶所歸屬的移動通信網
"locale" 地址改變了-----用戶選擇了一個新的語言會顯示出來
"touchscreen" 觸摸屏是改變了------一般是不會發生的
"keyboard" 鍵盤發生了改變----比如用戶用了外部的鍵盤
"keyboardHidden" 鍵盤的可用性發生了改變
"navigation" 導航發生了變化-----通常也不會發生
"screenLayout" 屏幕的顯示發生了變化------不同的顯示被激活
"fontScale" 字體比例發生了變化----選擇了不同的全局字體
"uiMode" 用戶的模式發生了變化
"orientation" 屏幕方向改變了
"screenSize" 屏幕大小改變了
"smallestScreenSize" 屏幕的物理大小改變了,如:連接到一個外部的屏幕上














今天收獲不小。見識了大公司的霸氣,也加深了android:configChanges屬性的了解。



免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM