您好,登錄后才能下訂單哦!
如何進行ANR簡述,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
什么是ANR?ANR即為Application Not Responding,也就是應用程序無響應。
Android系統中,ActivityManagerService(簡稱AMS)和WindowManagerService(簡稱WMS)會檢測App的響應時間,如果App在特定時間無法相應屏幕觸摸或鍵盤輸入時間,或者特定事件沒有處理完畢,就會出現ANR。
產生ANR的原因一般有以下三種:
1.點擊、觸摸、鍵盤輸入事件在5s內沒有及時響應(inputdispatch timeout)
2.廣播超時沒有響應,前臺廣播10s未響應,后臺廣播60s未響應 (Broadcast timeout)
3.service 20s 沒有響應 (service timeout)
現在我們通過一個分析實例來進行闡述,如何分析anr 的問題
1.首先我們要先分析一個anr的systemlog
通過搜索關鍵字“anr ”可以定位到在log中anr 發生的地方,如下圖
從systemlog中這段log,我們可以知道幾個關鍵的點
1.anr發生的進程名、進程號(PID: 1531)
2.anr發生的原因(如上點擊事件超時未響應)
3.anr發生的時候,當時的進程cpu占用情況,同時具體進程占用的上層和kernel層資源情況。
2.通過上一步的大致描述,找到anr發生的時間點
上面可以看到anr是因為點擊事件超時沒有響應,導致的anr,那么我們可以在這個時間點的前5s(個別定制化平臺可能時間不為5s),查看具體發生anr的進程(Pid 1531)在做什么。
在systemlog中查看到具體anr發生的時間點,以便我們了解該時間點的時候,系統進程在進行什么操作,同時,可以簡單看下我們的具體進程在進行什么操作
3.查找trcace文件,查看進程的堆棧(最重要的一步)
從這個截圖來看,我們首先找到pid 為1531的進程main進程,查看當時main進程卡死在什么地方。
從狀態native來看,是進程卡在了native層沒有及時返回,從堆棧來看進程是在操作imagePlayerManager.init
的時候,進行進程間通信,在native層卡主沒有及時返回。
所以此時要找到對應堆棧在代碼中的位置,查看具體耗時操作。查看卡主未返回的具體原因。
在耗時操作位置做規避來防止anr的發生。
導致ANR的情況還有很多,進程死循環、死鎖、耗時操作(網絡請求,圖片處理,數據庫處理等)卡死主線程。
后續找到經典案例繼續補充。
分析ANR需要trace文件這個是非常重要的一點。
關于如何進行ANR簡述問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。