当遇到Android手机UI冻结时,我们要怎么分析?
主要方法就是抓日志,看现象。
一般来说,手机UI冻结时,USB / ADB仍有响应,所以需要在设备冻结期间收集以下日志:
top,meminfo,bugreport,tombstone,anr等日志,
adb bugreport 目录
adb pull data/tombstones 目录
adb pull data/anr 目录
其他信息抓取方法可以参考其他文章。
1.优先在现场设备上调试UI冻结问题。检查logcat日志中的任何明显错误,top日志中的CPU利用率,UI卡在哪个屏幕上(主屏幕,应用程序屏幕等)。
2.执行命令“adb shell getevent”查看点击事件是否正常。
触摸屏幕,观察“adb shell getevent”的输出,看到触摸事件是否打印在屏幕。
按电源键和音量开关键。看屏幕上显示的按键事件。
此外,按下音量升降键通常会产生声音效果。按按钮查看是否可以听到按键音效。
3.检查是否有一个实际的UI冻结,或如果UI只是没有响应触摸输入:
执行命令“adb shell input keyevent 3”。将“3”替换为其他数字,以查看UI是否响应adb给出的输入。
尝试通过adb启动活动,例如使用:"am start 某应用包名”等。
4.如果可能,注意设备上显示的时间。时间是在变化还是被无限冻结?这将有助于将冻结与日志中的特定时间关联起来。
5.在'top'日志中,查看system_server或surfaceflinger的线程是否处于D状态。如果是这样,必须连接JTAG并查看它们各自的内核级任务。如果一切都没问题,可能是驱动的问题。
6.检查内核日志中的Low Memory Killer日志
版权归原作者 tianshi4851 所有, 如有侵权,请联系我们删除。