Android中ANR分析
2016-07-01 13:17
483 查看
本博客同步发表在http://hjxandhmr.github.io/2016/07/01/Android-ANRAnalysis/
BroadcastTimeout(10 seconds) –BroadcastReceiver在10秒内无法处理完成
ServiceTimeout(20 seconds) –Service在20秒内无法处理完成
使用AsyncTask处理耗时IO操作。
使用Thread或者HandlerThread时,调用Process.setThreadPriority(Process.THREAD_PRIORITY_
BACKGROUND)设置优先级,否则仍然会降低程序响应,因为默认Thread的优先级和主线程相同。
使用Handler处理工作线程结果,而不是使用Thread.wait()或者Thread.sleep()来阻塞主线程。
Activity的onCreate和onResume回调中尽量避免耗时的代码
BroadcastReceiver中onReceive代码也要尽量减少耗时,建议使用IntentService处理。
从trace.txt文件查看调用stack.
看代码
仔细查看ANR的成因(iowait?block?memoryleak?)
这里有两篇博客关于ANR写的非常详细,感兴趣的可以移步到下面链接去更深入的学习。
http://www.cnblogs.com/purediy/p/3225060.html
http://droidyue.com/blog/2015/07/18/anr-in-android/index.html
什么是ANR
ANR全称Application Not Responding,意思就是程序未响应。如果一个应用无法响应用户的输入,系统就会弹出一个ANR对话框,如下图所示,用户可以自行选择继续等待亦或者是停止当前程序。什么会引发ANR
KeyDispatchTimeout(5 seconds) –主要类型按键或触摸事件在5秒内无响应BroadcastTimeout(10 seconds) –BroadcastReceiver在10秒内无法处理完成
ServiceTimeout(20 seconds) –Service在20秒内无法处理完成
如何避免ANR
基本的思路就是将IO操作在工作线程来处理,减少其他耗时操作和错误操作使用AsyncTask处理耗时IO操作。
使用Thread或者HandlerThread时,调用Process.setThreadPriority(Process.THREAD_PRIORITY_
BACKGROUND)设置优先级,否则仍然会降低程序响应,因为默认Thread的优先级和主线程相同。
使用Handler处理工作线程结果,而不是使用Thread.wait()或者Thread.sleep()来阻塞主线程。
Activity的onCreate和onResume回调中尽量避免耗时的代码
BroadcastReceiver中onReceive代码也要尽量减少耗时,建议使用IntentService处理。
分析并解决ANR
首先分析log从trace.txt文件查看调用stack.
看代码
仔细查看ANR的成因(iowait?block?memoryleak?)
这里有两篇博客关于ANR写的非常详细,感兴趣的可以移步到下面链接去更深入的学习。
http://www.cnblogs.com/purediy/p/3225060.html
http://droidyue.com/blog/2015/07/18/anr-in-android/index.html
相关文章推荐
- 使用C++实现JNI接口需要注意的事项
- Android IPC进程间通讯机制
- Android Manifest 用法
- [转载]Activity中ConfigChanges属性的用法
- Android之获取手机上的图片和视频缩略图thumbnails
- Android之使用Http协议实现文件上传功能
- Android学习笔记(二九):嵌入浏览器
- android string.xml文件中的整型和string型代替
- i-jetty环境搭配与编译
- android之定时器AlarmManager
- android wifi 无线调试
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- android 代码实现控件之间的间距
- android FragmentPagerAdapter的“标准”配置
- Android"解决"onTouch和onClick的冲突问题
- android:installLocation简析
- android searchView的关闭事件
- SourceProvider.getJniDirectories