ANR
来源:互联网 发布:mac电脑excel换行 编辑:程序博客网 时间:2024/05/14 01:59
ANR
1、ANR排错一般有三种类型
- KeyDispatchTimeout(5 seconds) --主要是类型按键或触摸事件在特定时间内无响应
- BroadcastTimeout(10 seconds) --BroadcastReceiver在特定时间内无法处理完成
- ServiceTimeout(20 secends) --小概率事件 Service在特定的时间内无法处理完成
2、哪些操作会导致ANR 在主线程执行以下操作: 1. 高耗时的操作,如图像变换 2. 磁盘读写,数据库读写操作 3. 大量的创建新对象
3、如何避免
- UI线程尽量只做跟UI相关的工作
- 耗时的操作(比如数据库操作,I/O,连接网络或者别的有可能阻塞UI线程的操作)把它放在单独的线程处理
- 尽量用Handler来处理UIThread和别的Thread之间的交互
4、解决的逻辑 1. 使用AsyncTask 1. 在doInBackground()方法中执行耗时操作 2. 在onPostExecuted()更新UI 2. 使用Handler实现异步任务 1. 在子线程中处理耗时操作 2. 处理完成之后,通过handler.sendMessage()传递处理结果 3. 在handler的handleMessage()方法中更新UI 4. 或者使用handler.post()方法将消息放到Looper中
5、如何排查
- 首先分析log
- 从trace.txt文件查看调用stack,adb pull data/anr/traces.txt ./mytraces.txt
- 看代码
- 仔细查看ANR的成因(iowait?block?memoryleak?)
6、监测ANR的Watchdog
最近出来一个叫LeakCanary
FC(Force Close)
什么时候会出现
- Error
- OOM,内存溢出
- StackOverFlowError
- Runtime,比如说空指针异常
解决的办法
- 注意内存的使用和管理
- 使用Thread.UncaughtExceptionHandler接口
0 0
- ANR
- ANR
- ANR
- anr
- ANR
- ANR
- ANR
- ANR
- ANR
- ANR
- ANR
- ANR
- ANR
- ANR
- ANR
- ANR
- ANR
- ANR
- 图解 Android 事件分发机制
- 第二章小结
- 逃亡的准备(多重背包+二进制优化)
- 在Ubuntu下安装torch7
- JAVA进阶7.6——数据流传输
- ANR
- POJ 2406 Power Strings(next数组应用)
- 2016.10.05【初中部 NOIP普及组 】模拟赛
- 同一个世界【c语言闯关】
- 堆排序小根堆 大根堆 迭代 递归 总结 完整代码
- Java线程池总结
- css里同一个标签定义了两种样式,哪一个有效?
- 2016.10.5总结
- 2016.10.05【初中部 NOIP普及组 】模拟赛题解