1、ANR介绍
ANR(Application Not Responding)指的是应用程序无响应,当Android应用程序在主线程上执行长时间运行的操作或阻塞I/O操作时发生。这可能导致应用程序界面冻结或无法响应用户输入。
1、Service ANR:前台20s,后台200s;startForeground超时10s
2、BroadcastReceiver ANR:前台10s,后台60s
3、Input ANR:按键或触摸事件在5s内无响应
4、ContentProvider ANR:10s,少见
2、抓取离线日志
data:image/s3,"s3://crabby-images/ef3de/ef3dee6dfc941da7b9dffbb58ee3341f8b840263" alt=""
使用CAT或QATT解析dbg文件
data:image/s3,"s3://crabby-images/45c18/45c18666f73d4fd0b4d1710f53fc96c176a6f128" alt=""
data:image/s3,"s3://crabby-images/a27c9/a27c9369225c518e81d3be46918ce86065b64992" alt=""
解析完成相关Log如下
data:image/s3,"s3://crabby-images/1dca6/1dca6fdeb0057c0d756b6560f7ebab6a4452de4d" alt=""
3、Service ANR
Service ANR原理,当框架启动APP对应的Service时。一边在框架自身发起一个handler超时消息,一边发送启动Service 的handler消息到APP的主线程。当APP Service中的onCreate方法调用后,会回调框架中的serviceDoneExecutingLocked来取消定超时消息。正常情况下如此
data:image/s3,"s3://crabby-images/224bf/224bfdbbc16f3777ce12f61189aff224e3fb84a3" alt=""
如果是APP本身问题,可以通过SYS_FTRACE搜索serviceCreate来确定执行时长。
data:image/s3,"s3://crabby-images/46fb1/46fb1823c3420106bb8d19a6f9b36fa861baf0ad" alt=""
同步其他Log进行分析确认。
data:image/s3,"s3://crabby-images/18de5/18de566725cfe437df98b4fd3b3b54468987cc89" alt=""
执行超时消息,触发ANR
1、若binder耗时(比较少见);
2、app主线程执行一些消息耗时,导致service相关的消息得不到执行;
3、Service本身的周期方法onCreate,onStartCommand等执行一些耗时操作;
4、BroacastReceiver 超时
Android中有两种广播机制:
1、静态广播接收者:通过AndroidManifest.xml的标签来申明的BroadcastReceiver。
2、动态广播接收者:通过Context.registerReceiver()方式注册的BroadcastReceiver,动态注册更为灵活,可在不需要时通过unregisterReceiver()取消注册。
从广播发送方式可分为三类:
1、普通广播:通过Context.sendBroadcast()发送,可并行处理
2、有序广播:通过Context.sendOrderedBroadcast()发送,串行处理
3、Sticky广播:通过Context.sendStickyBroadcast()发送
其中前台广播ANR 10s,后台广播ANR 60s
data:image/s3,"s3://crabby-images/584c8/584c8afb4465000047ac85ff16aca3f5e8b6566e" alt=""
data:image/s3,"s3://crabby-images/f928b/f928ba74bbe9b9bd06a1802c93f630dceb02a4f2" alt=""
发送广播的逻辑主要在框架中的BroadcastQueue的函数processNextBroadcastLocked中。对于并行广播mParallelBroadcasts直接全部发送。对于有序广播,每次设置超时时间,发送一条。APP接收到关播后,调用finish来进行下一条循环。
data:image/s3,"s3://crabby-images/f3691/f369151ac0defc9e15b5d37e786017ce8d36cc24" alt=""
如果是APP本身问题,可以通过SYS_FTRACE搜索broadcastReceiveComp来确定执行时长。
data:image/s3,"s3://crabby-images/083bd/083bdad52c5c4b0ef966f88ad4a42929743885fb" alt=""
data:image/s3,"s3://crabby-images/a289a/a289a1ef1886235d47031005f404a86f4d748011" alt=""
5、Input超时
data:image/s3,"s3://crabby-images/f6131/f6131e57830acb3447b7c515283a6d7eb3c6c791" alt=""
检查 Relayout windows时间点(此时 activity 能被看到)。如果发 生 ANR 时,Focus焦点已经切换过来,则需要APP分析,否则需要系统侧进一步分析。
data:image/s3,"s3://crabby-images/8c985/8c9859a4e41ee92bd46a3bc9b58172580a179f6d" alt=""
其中绘制过程比较复杂,相关流程整理如下,后续更新
data:image/s3,"s3://crabby-images/bb3d6/bb3d68af69912176f4fc4746e0f33a08b5fa56ac" alt=""
6、 ContentProvider 超时
后续补充
7、其他相关信息确认
很多时候,ANR不一定是APP本身的问题,有可能是系统卡顿或者IO问题导致的。需要结合相关ANR Log中的其他信息一起分析。
1、CPU的使用率
data:image/s3,"s3://crabby-images/a4b2d/a4b2d1793eb8e8cf6f0c97031daca0b53ef014de" alt=""
2、剩余内存大小
data:image/s3,"s3://crabby-images/ba728/ba7287070bc920eee781857f17d5956037373ea6" alt=""
EVENT Log中搜killinfo
data:image/s3,"s3://crabby-images/26abf/26abf8f03f3eac5e85a6a8b59e07471e7f2daa9e" alt=""
参考文档