1.環境搭建
a.下載安卓SDK
鏈接:https://pan.baidu.com/s/1-OB6UVPvl5-N-vFdykfMmA
提取碼:3spx
b.配置環境變量(配置完成,重啟系統,配置生效)
c.測試安卓環境搭建成功
- 打開手機的開發者模式
- 使用數據線,連接安卓手機。
- 是否允許訪問手機數據,選擇 是;允許USB調試嗎,一律允許。
- 打開cmd,輸入命令:adb devices,結果如下圖所示,環境搭建成功。
2.具體操作:
a.啟動待測APP,在cmd中輸入命令 獲取包名
adb shell "dumpsys window w|grep \/|grep name=|sed 's/mSurface=Surface(name=//g'|sed 's/)//g'|sed 's/ //g'"
如下圖所示,com開頭的就是包名
b.執行 monkey測試,並把執行日志記錄到指定位置。
在cmd輸入命令adb shell monkey -p 包名 -v -v -v 100 >d:\test.txt,
100指的是發送的隨機事件個數(這時候可以觀察手機APP在各種操作下的反應)
c.如何確認monkey測試發現了問題呢?分析日志
從日志中搜索:exception、crash、ANR 這3個關鍵詞。monkey的錯誤一般都是這3個,異常,崩潰,程序終止。找到錯誤了日志后面會有原因的,給開發看就是了
解釋一下什么是 ANR錯誤:
ANR (Application Not Responding)
ANR定義:在Android上,如果你的應用程序有一段時間響應不夠靈敏,系統會向用戶顯示一個對話框,這個對話框稱作應用程序無響應(ANR:Application Not Responding)對話框。用戶可以選擇“等待”而讓程序繼續運行,也可以選擇“強制關閉”。所以一個流暢的合理的應用程序中不能出現anr,而讓用戶每次都要處理這個對話框。因此,在程序里對響應性能的設計很重要,這樣系統不會顯示ANR給用戶。
默認情況下,在android中Activity的最長執行時間是5秒,BroadcastReceiver的最長執行時間則是10秒。
第一:什么會引發ANR?
在Android里,應用程序的響應性是由Activity Manager和WindowManager系統服務監視的 。當它監測到以下情況中的一個時,Android就會針對特定的應用程序顯示ANR:
1.在5秒內沒有響應輸入的事件(例如,按鍵按下,屏幕觸摸)
2.BroadcastReceiver在10秒內沒有執行完畢
3.service是20
造成以上兩點的原因有很多,比如在主線程中做了非常耗時的操作,比如說是下載,io異常等。
潛在的耗時操作,例如網絡或數據庫操作,或者高耗時的計算如改變位圖尺寸,應該在子線程里(或者以數據庫操作為例,通過異步請求的方式)來完成。
原創文章,轉載請注明出處。