Android ANR问题分析
2017-12-02 16:34
281 查看
1.Android ANR问题报错一般有3种情况
类型按键或触摸事件在5秒内无响应
BroadcastReceiver在10秒内无法处理完成
Service在20秒内无法处理完成
2.产生ANR的原因
在主线程种进行如下操作:
高耗时的操作,如图像变换
磁盘读写,数据库读写操作
大量的创建新对象
3.如何避免ANR
UI线程尽量只做跟UI相关的工作
耗时的操作(比如数据库操作,I/O,连接网络或者别的有可能阻塞UI线程的操作)把它放在单独的线程处理
尽量用Handler来处理UIThread和别的Thread之间的交互
4.解决的逻辑
使用AsyncTask:
在doInBackground()方法中执行耗时操作
在onPostExecuted()更新UI
使用Handler实现异步任务:
在子线程中处理耗时操作
处理完成之后,通过handler.sendMessage()传递处理结果
在handler的handleMessage()方法中更新UI
或者使用handler.post()方法将消息放到Looper中
5.怎么排查ANR产生的原因
首先分析log
从trace.txt文件查看调用stack,adb pull
data/anr/traces.txt ./mytraces.txt
看代码
仔细查看ANR的成因(iowait?block?memoryleak?)
拓展: Force Close什么时候会出现
Error
OOM,内存溢出
StackOverFlowError
Runtime,比如说空指针异常
解决的办法
注意内存的使用和管理
使用Thread.UncaughtExceptionHandler接口
类型按键或触摸事件在5秒内无响应
BroadcastReceiver在10秒内无法处理完成
Service在20秒内无法处理完成
2.产生ANR的原因
在主线程种进行如下操作:
高耗时的操作,如图像变换
磁盘读写,数据库读写操作
大量的创建新对象
3.如何避免ANR
UI线程尽量只做跟UI相关的工作
耗时的操作(比如数据库操作,I/O,连接网络或者别的有可能阻塞UI线程的操作)把它放在单独的线程处理
尽量用Handler来处理UIThread和别的Thread之间的交互
4.解决的逻辑
使用AsyncTask:
在doInBackground()方法中执行耗时操作
在onPostExecuted()更新UI
使用Handler实现异步任务:
在子线程中处理耗时操作
处理完成之后,通过handler.sendMessage()传递处理结果
在handler的handleMessage()方法中更新UI
或者使用handler.post()方法将消息放到Looper中
5.怎么排查ANR产生的原因
首先分析log
从trace.txt文件查看调用stack,adb pull
data/anr/traces.txt ./mytraces.txt
看代码
仔细查看ANR的成因(iowait?block?memoryleak?)
拓展: Force Close什么时候会出现
Error
OOM,内存溢出
StackOverFlowError
Runtime,比如说空指针异常
解决的办法
注意内存的使用和管理
使用Thread.UncaughtExceptionHandler接口
相关文章推荐
- Android-ANR问题分析
- Android中的ANR(Application Not Responding)问题分析
- Android ANR问题分析
- Android ANR问题原因分析
- Android ANR问题分析
- android ANR问题分析指北
- Android ANR问题分析[转]
- android 分析ANR问题
- Android ANR问题分析思路
- Android平台上的ANR问题分析方法
- Android ANR问题分析[转]
- 【Android】[转] ANR的分析和问题处理
- Android ANR和Crash问题小结--分析log
- Android稳定性问题---ANR问题分析
- Android问题分析之ANR
- Android ANR问题分析思路
- Android权限机制总结与常见权限不足问题分析
- [Android 评论分析] HTML 5是不是解决跨平台问题的终极密钥?
- 编写Android app更新模块遇到的问题分析与总结
- [转]android listview 连续调用 getview问题分析及解决