ANR异常知识点

来源:互联网 发布:风力太阳能路灯 知乎 编辑:程序博客网 时间:2024/06/05 00:25

什么是ANR

ANR的全称为Application Not Responding(应用程序无响应)。当Activity卡顿时间超过5秒,即会出现ANR弹框。在BroadcastReceiver中最长的执行时间为10秒,如果10秒内没有执行操作,即会出现ANR弹框。Service中20秒内没有处理完操作,即会出现ANR异常。

造成ANR的主要原因

  • 主线程被IO操作(从4.0之后网络IO不允许在主线程中)阻塞
  • 主线程中存在耗时的计算

Android中哪些操作是在主线程中?

  • Activity的所有生命周期回调
  • Service默认是执行在主线程中
  • BroadcastReceiver的onReceive回调是执行在主线程的
  • 没有使用子线程的looper的Handler的handleMessage,post(Runnable)是执行在主线程的
  • AsyncTask的回调中除了doInBackground,其他都是执行在主线程中

ANR的定位和分析

当发生ANR时,通过Logcat日志和生成的位于手机内部存储的/data/anr/traces.txt文件进行分析和定位

如何解决ANR

  • 使用Asynctask处理耗时IO操作
  • 使用Thread或者HandlerThread提高优先级
  • 使用Handler来处理工作线程的耗时任务
  • Activity的onCreate和onResume回调中尽量避免耗时的代码

ANR检测工具

  1. StrictMode是Android SDK提供的一个用来检测代码中是否存在违规操作的工具类。StrictMode主要检测两大类,一类是线程策略ThreadPolicy,另一类是虚拟机策略VmPlicy。
  2. BlockCanary是一个非侵入式的性能监控函数库,主要用来监控应用主线程的卡顿。基本原理是利用主线程的消息队列处理机制,通过对比消息分发开始和结束的时间点来判断是否超过设定的时间,如果是,则判断为主线程卡顿。