android-ANR的解析

来源:互联网 发布:pc围棋软件 编辑:程序博客网 时间:2024/06/07 03:07
#ANR---1、ANR排错一般有三种类型1. KeyDispatchTimeout(5 seconds) --主要是类型按键或触摸事件在特定时间内无响应2. BroadcastTimeout(10 seconds) --BroadcastReceiver在特定时间内无法处理完成3. ServiceTimeout(20 secends) --小概率事件 Service在特定的时间内无法处理完成2、哪些操作会导致ANR在主线程执行以下操作:1. 高耗时的操作,如图像变换2. 磁盘读写,数据库读写操作3. 大量的创建新对象3、如何避免1. UI线程尽量只做跟UI相关的工作2. 耗时的操作(比如数据库操作,I/O,连接网络或者别的有可能阻塞UI线程的操作)把它放在单独的线程处理3. 尽量用Handler来处理UIThread和别的Thread之间的交互4、解决的逻辑1. 使用AsyncTask1. 在doInBackground()方法中执行耗时操作2. 在onPostExecuted()更新UI2. 使用Handler实现异步任务1. 在子线程中处理耗时操作2. 处理完成之后,通过handler.sendMessage()传递处理结果3. 在handler的handleMessage()方法中更新UI4. 或者使用handler.post()方法将消息放到Looper中5、如何排查1. 首先分析log2. 从trace.txt文件查看调用stack,adb pull data/anr/traces.txt ./mytraces.txt3. 看代码4. 仔细查看ANR的成因(iowait?block?memoryleak?)6、监测ANR的Watchdog最近出来一个叫LeakCanary#FC(Force Close)##什么时候会出现1. Error2. OOM,内存溢出3. StackOverFlowError4. Runtime,比如说空指针异常##解决的办法1. 注意内存的使用和管理2. 使用Thread.UncaughtExceptionHandler接口转自:https://github.com/francistao/LearningNotes/blob/master/Part1/Android/ANR%E9%97%AE%E9%A2%98.md
原创粉丝点击