1. 什么是ANR?
ANR:Application Not Responding,即应用无响应,
Android系统对于一些事件需要在一定的时间范围内完成,如果超过预定时间能未能得到有效响应或者响应时间过长,都会造成ANR。一般地,这时往往会弹出一个提示框,告知用户当前xxx未响应,用户可选择继续等待或者Force
Close。
2. ANR出现场景
- InputDispatching Timeout: 输入事件分发超时5s,包括按键分发事件的超时。
- Service Timeout:前台服务在20s内未执行完成,后台服务200s;
- ContentProvider Timeout:内容提供者执行超时
- BroadcastQueue Timeout:前台广播在10s内未执行完成,后台广播60s
3. ANR实现原理
主体实现是在系统层
核心原理:消息调度,超时处理
消息经系统进程system_server
调度,派发到应用进程完成对消息的实际处理,
Android系统ANR的实现,基本都是基于Handler消息机制来完成的。前面说过响应超时的定义,那么在一个事件执行开始时,通过Handler去post一个对应时间的延迟消息,如果事件在规定事件内执行完成,就remove掉这个message,否则,Handler就会收到这个ANR的Message,做进一步处理,dump日志,弹出ANR对话框
4. 可能导致ANR的原因
- 线程问题,如主线程被join/sleep,或wait锁等导致超时
- CPU不足,一般是别的App占用了大量的CPU,导致App无法及时处理
5. 哪些地方是执行在主线程的
- Activity的所有生命周期回调都是执行在主线程的.
- Service默认是执行在主线程的.
6. 日常开发中如何避免ANR
- 避免在主线程进行复杂耗时的操作,特别是文件读取或者数据库操作
- 避免频繁实时更新UI
- 在设计及代码编写阶段避免出现出现同步/死锁或者错误处理不恰当等情况