Android ANR的原因及定位
2016-04-22 20:52
393 查看
ANR定义:在Android上,如果你的应用程序有一段时间响应不够灵敏,系统会向用户显示一个对话框,这个对话框称作应用程序无响应(ANR:Application Not Responding)对话框。用户可以选择“等待”而让程序继续运行,也可以选择“强制关闭”。
ANR产生的条件:在Android里,应用程序的响应性是由Activity Manager和WindowManager系统服务监视的 。当它监测到以下情况中的一个时,Android就会针对特定的应用程序显示ANR:
默认情况下,在android中Activity的最长执行时间是5秒,BroadcastReceiver的最长执行时间则是10秒。
ANR产生的原因:1. 主线程中做了非常耗时的操作 2. 在BroadcastReceiver里做耗时的操作或计算 3.CPU使用过高 4.发生了死锁 等等。
避免ANR的方式: 1、运行在主线程里的任何方法都尽可能少做事情。特别是,Activity应该在它的关键生命周期方法(如onCreate()和onResume())里尽可能少的去做创建操作。(可以采用重新开启子线程的方式,然后使用Handler+Message的方式做一些操作,比如更新主线程中的ui等) 2.别在BroadcastReceiver里做耗时的操作 。。。
ANR定位: 一般情况下,如果有ANR发生,系统都会在/data/anr/目录下生成traces.txt文件,通过分析traces.txt 文件,可以查看产生ANR的原因。(手机要root)
ANR产生的条件:在Android里,应用程序的响应性是由Activity Manager和WindowManager系统服务监视的 。当它监测到以下情况中的一个时,Android就会针对特定的应用程序显示ANR:
1.在5秒内没有响应输入的事件(例如,按键按下,屏幕触摸) 2.BroadcastReceiver在10秒内没有执行完毕
默认情况下,在android中Activity的最长执行时间是5秒,BroadcastReceiver的最长执行时间则是10秒。
ANR产生的原因:1. 主线程中做了非常耗时的操作 2. 在BroadcastReceiver里做耗时的操作或计算 3.CPU使用过高 4.发生了死锁 等等。
避免ANR的方式: 1、运行在主线程里的任何方法都尽可能少做事情。特别是,Activity应该在它的关键生命周期方法(如onCreate()和onResume())里尽可能少的去做创建操作。(可以采用重新开启子线程的方式,然后使用Handler+Message的方式做一些操作,比如更新主线程中的ui等) 2.别在BroadcastReceiver里做耗时的操作 。。。
ANR定位: 一般情况下,如果有ANR发生,系统都会在/data/anr/目录下生成traces.txt文件,通过分析traces.txt 文件,可以查看产生ANR的原因。(手机要root)
adb shell su cd data/anr cat traces.txt
相关文章推荐
- Android 读取assets目录下的db文件
- Unable to get the focused window from device - android
- 【Android 学习】实现仿360悬浮窗
- android 简单拨号器 代码
- Android Studio 加载.so注意事项
- 【补丁】在vs2015、vs emulator for android下挪动android sdk文件夹
- 兼容IOS android 页面滑动的CSS设置
- android+html5 上传图片兼容4.0 5.0 6.0
- 手机在 Android studio 中不显示logcat信息
- 我对Android的认识
- android学习之绑定Service并与之通信
- 不翻墙,利用国内源下载Android 源码
- Android中Scrollview、ViewPager、ListView冲突问题 (亲测可用)
- Android ecludeFromRecents
- Android 程序进入后台 恢复到前台
- Android IntentService完全解析 当Service遇到Handler
- Android HandlerThread 完全解析
- Android保存用户名等小数据使用SharedPreference
- Android生成一维码
- android实现qq邮箱多个图标效果