AndroidL ANR分析整理
来源:互联网 发布:图像边缘检测各种算法 编辑:程序博客网 时间:2024/05/22 00:07
ANR简介
一:什么是ANR
ANR:Application Not Responding,即应用无响应
二:ANR的类型
ANR一般有三种类型:
1:KeyDispatchTimeout(5 seconds) --主要类型
按键或触摸事件在特定时间内无响应,超时时间为ActivityManagerService.java中的KEY_DISPATCHING_TIMEOUT
2:BroadcastTimeout(10 seconds)
BroadcastReceiver在特定时间内无法处理完成
3:ServiceTimeout(20 seconds) --小概率类型
Service在特定的时间内无法处理完成
三:ANR日志
ANR 日志在 /data/anr 目录下
四:为什么会超时呢?
超时时间的计数一般是从按键分发给app开始。超时的原因一般有两种:
1:当前的事件没有机会得到处理(即UI线程正在处理前一个事件,没有及时的完成或者looper被某种原因阻塞住了)
2:当前的事件正在处理,但没有及时完成
五:如何避免KeyDispatchTimeout
1:UI线程尽量只做跟UI相关的工作
2:耗时的工作(比如数据库操作,I/O,连接网络或者别的有可能阻碍UI线程的操作)把它放入单独的线程处理
3:尽量用Handler来处理UIthread和别的thread之间的交互
六:UI线程
说了那么多的UI线程,那么哪些属于UI线程呢?
UI线程主要包括如下:
1:Activity:onCreate(), onResume(), onDestroy(), onKeyDown(),onClick(),etc
2:AsyncTask: onPreExecute(), onProgressUpdate(), onPostExecute(),onCancel,etc
3:Mainthread handler: handleMessage(), post*(runnable r), etc
4:other
七:关键字
1:”anr” –注意后面的空格,可以省去好多无用信息
2:KeyDispatchTimeout
八:ANR发生情况
1:死锁
2:CPU使用量接近100%
3:主线程中进行网络操作,读写数据库,死循环等
- AndroidL ANR分析整理
- AndroidL分析之Keyguard
- androidL init 进程源码分析
- anr 分析
- ANR分析
- ANR分析
- ANR分析
- ANR分析
- ANR分析
- anr分析
- ANR分析
- 分析ANR
- ANR分析
- anr分析
- ANR分析
- ANR分析
- ANR分析
- anr分析
- 深入理解Android(4)——理解Android中的JNI(下)
- Jquery根据元素值或元素下标来删除一个数组元素及数组对象方法
- excel公式:获取两列数据中相同的数据,并展示在第三列。
- sumline text 正则匹配
- Android二维码讲解(ZXing)
- AndroidL ANR分析整理
- 黑客攻击的入口--端口
- 一个apk多个入口,在桌面上创建多个应用图标的桌面快捷方式
- java生成二维码
- 1019. General Palindromic Number (20)
- c3p0数据库连接池问题-----不能取到连接An attempt by a client to checkout a Connection has timed out(问题还没有解决)
- MySQL学习1-软件下载
- mysql修改表、字段、库的字符集
- AndroidManifest.xml文件配置整理集合