android ANR分析

来源:互联网 发布:淘宝商盟官网 编辑:程序博客网 时间:2024/06/08 10:04

1.ANR排错一般有三中种类型

    1)KeyDispatchTimeout(5s) 主要是类型案件或触摸事件在特定时间内无响应

    2)BroadcastTimeout(10s) BroadcastReceiver在特定时间内无法处理完成

    3)ServiceTimeout(20s) 小概率事件Service在特定时间内无法处理完成


2.哪些操作会导致ANR

    在主线程中执行以下操作:

    1)高好使操作,如图像变换

    2)磁盘读写,数据库读写操作

    3)大量的窗体对象


3.如何避免

    1)UI线程尽量只做跟UI相关的工作

    2)耗时操作(比如数据库,IO,链接网络或者别的有可能阻塞UI线程的操作)把它放在单独的线程中处理

    3)尽量用Handler来处理UIThread和别的线程之间的交换


4.解决逻辑

    1)使用AsyncTask,在doInBackground方法中做耗时操作,在postExecute执行更新UI操作

    2)使用Handler实现异步任务,在子线程中执行耗时操作,处理完后通过message传递处理结果

          在handler的HandleMessage方法中更新UI,或者使用Handler.post方法将消息放到Looper中


5.如何排查

    1)首先分析log

    2)从trace.txt文件中查看调用stack,adb pull data/anr/trace.txt ./mytraces.txt    

    3)看代码

    4)仔细查看ANR的成因


6.监测ANR的Watchdog

    LeakCanary


FC(Force Close)

1.什么时候出现

    1)ERROR

    2)OOM内存溢出

    3)StackOverFlowError

    4)RuntimeError 比如空指针

2.解决办法

    1)主要内存的使用和管理

    2)使用Thread.UncaughtExceptionHandler接口捕获崩溃


0 0
原创粉丝点击