ANR的简单介绍及解决方法
2016-10-08 14:39
113 查看
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
Error
OOM,内存溢出
StackOverFlowError
Runtime,比如说空指针异常
注意内存的使用和管理
使用Thread.UncaughtExceptionHandler接口
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)
什么时候会出现
ErrorOOM,内存溢出
StackOverFlowError
Runtime,比如说空指针异常
解决的办法
注意内存的使用和管理使用Thread.UncaughtExceptionHandler接口
相关文章推荐
- Linux下cannot open shared object file: No such file or directory解决方法简单介绍
- 简单介绍下phpmyadmin 403错误的解决方法
- 快速解决jquery之get缓存问题的最简单方法介绍
- 快速解决jquery之get缓存问题的最简单方法介绍
- 快速解决jquery之get缓存问题的最简单方法介绍
- 简单介绍下phpmyadmin 403错误的解决方法
- 快速解决jquery之get缓存问题的最简单方法介绍
- Python3.4出现unable to find vcvarsall.bat的简单解决方法
- 创建UDF的简单方法介绍
- 创建UDF的简单方法介绍
- 发送邮件常见出错代码及简单解决方法
- js call 方法简单介绍
- (转)TreeSet简单介绍与使用方法
- 依赖冲突详细介绍及其解决方法
- 登录织梦后台提示用户名不存在的解决方法介绍
- Error:Jack is required to support java 8 language features. 异常解决方法及介绍
- 百度地图插件的调用方法的简单介绍
- 简单介绍区分applet和application的方法
- onMeasure简单方法 完美解决ListView与ScollView冲突问题!
- php -- 魔术方法、魔术常量 简单介绍