ANR异常分析

ANR分析:通过log和trace文件

pull出/data/anr/traces.txt文件

 

一些关键字:suspend all histogram、anr。查看CPU使用情况(关键字CUP usage from )

 

一些会出ANR的情况:

1、用户在进行了一种操作后5秒钟没有响应

2、Service在20秒内没返回结果

3、BroadcastReceiver是在程序主线程运行,而且默认情况下BroadcastReceiver的运行时间为10s。在一个BroadcastReceiver中的onReceive方法中的处理不能超过10秒,如果超过就会出现ANR错误。

所有尽量不要在onReceive中做耗时的处理,最好用Service来处理。(不要另外开启线程,因为这个线程会随着onReceive的返回而终止。)

死锁,两个锁各自被占用,又都想申请对方的锁

UI线程一定要只做刷新UI动作

UI线程最好只做界面相关的动作,不要为了偷懒少些几行代码就把整个数据抛给UI线程,并发大的时候会丢失数据。
数据的各种格式和逻辑要在子线程中判断,把不需要刷新UI的数据拦截下来并抛掉,总之就是不要频繁刷新UI。

你可能感兴趣的:(异常分析)