91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何進行ANR簡述

發布時間:2022-01-07 21:10:02 來源:億速云 閱讀:199 作者:柒染 欄目:軟件技術

如何進行ANR簡述,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

ANR簡述以及分析流程

ANR簡介

什么是ANR?ANR即為Application Not Responding,也就是應用程序無響應。

ANR的原因

Android系統中,ActivityManagerService(簡稱AMS)和WindowManagerService(簡稱WMS)會檢測App的響應時間,如果App在特定時間無法相應屏幕觸摸或鍵盤輸入時間,或者特定事件沒有處理完畢,就會出現ANR。
產生ANR的原因一般有以下三種:
1.點擊、觸摸、鍵盤輸入事件在5s內沒有及時響應(inputdispatch timeout)
2.廣播超時沒有響應,前臺廣播10s未響應,后臺廣播60s未響應 (Broadcast timeout)
3.service 20s 沒有響應 (service timeout)

ANR的分析流程

現在我們通過一個分析實例來進行闡述,如何分析anr 的問題

1.首先我們要先分析一個anr的systemlog
通過搜索關鍵字“anr ”可以定位到在log中anr 發生的地方,如下圖
如何進行ANR簡述

從systemlog中這段log,我們可以知道幾個關鍵的點
1.anr發生的進程名、進程號(PID: 1531)
2.anr發生的原因(如上點擊事件超時未響應)
3.anr發生的時候,當時的進程cpu占用情況,同時具體進程占用的上層和kernel層資源情況。

2.通過上一步的大致描述,找到anr發生的時間點
上面可以看到anr是因為點擊事件超時沒有響應,導致的anr,那么我們可以在這個時間點的前5s(個別定制化平臺可能時間不為5s),查看具體發生anr的進程(Pid 1531)在做什么。
如何進行ANR簡述

在systemlog中查看到具體anr發生的時間點,以便我們了解該時間點的時候,系統進程在進行什么操作,同時,可以簡單看下我們的具體進程在進行什么操作

3.查找trcace文件,查看進程的堆棧(最重要的一步)
如何進行ANR簡述
從這個截圖來看,我們首先找到pid 為1531的進程main進程,查看當時main進程卡死在什么地方。
從狀態native來看,是進程卡在了native層沒有及時返回,從堆棧來看進程是在操作imagePlayerManager.init
的時候,進行進程間通信,在native層卡主沒有及時返回。
所以此時要找到對應堆棧在代碼中的位置,查看具體耗時操作。查看卡主未返回的具體原因。
在耗時操作位置做規避來防止anr的發生。

導致ANR的情況還有很多,進程死循環、死鎖、耗時操作(網絡請求,圖片處理,數據庫處理等)卡死主線程。
后續找到經典案例繼續補充。
分析ANR需要trace文件這個是非常重要的一點。

關于如何進行ANR簡述問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

anr
AI

韩城市| 独山县| 叙永县| 庄浪县| 铜川市| 新津县| 松原市| 奈曼旗| 芦山县| 灯塔市| 南郑县| 庐江县| 宁明县| 沁源县| 南阳市| 蒙自县| 香格里拉县| 新乡县| 湘乡市| 彭州市| 罗江县| 荔浦县| 巴南区| 永兴县| 上虞市| 塔河县| 徐水县| 乌鲁木齐县| 庆城县| 渝北区| 沭阳县| 崇文区| 江油市| 双牌县| 贵德县| 南丹县| 横峰县| 香港| 临汾市| 九江市| 宜兴市|