ANR

本文详细介绍了Android中ANR(应用无响应)与FC(强制关闭)的问题,包括其产生的原因、分类、如何避免及排查的方法。同时,还提供了一些实用的解决方案,帮助开发者更好地理解和解决这些问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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. 使用AsyncTask 1. 在doInBackground()方法中执行耗时操作 2. 在onPostExecuted()更新UI 2. 使用Handler实现异步任务 1. 在子线程中处理耗时操作 2. 处理完成之后,通过handler.sendMessage()传递处理结果 3. 在handler的handleMessage()方法中更新UI 4. 或者使用handler.post()方法将消息放到Looper中

5、如何排查

  1. 首先分析log
  2. 从trace.txt文件查看调用stack,adb pull data/anr/traces.txt ./mytraces.txt
  3. 看代码
  4. 仔细查看ANR的成因(iowait?block?memoryleak?)

6、监测ANR的Watchdog

最近出来一个叫LeakCanary

FC(Force Close)

什么时候会出现

  1. Error
  2. OOM,内存溢出
  3. StackOverFlowError
  4. Runtime,比如说空指针异常

解决的办法

  1. 注意内存的使用和管理
  2. 使用Thread.UncaughtExceptionHandler接口
### ANR (Application Not Responding) 原因及解决方法 #### 主要成因 ANR现象主要发生在应用程序的用户界面(UI)线程未能在规定时间内完成特定任务的情况下。具体来说: - **按键或触摸事件**:如果这些交互事件超过5秒未被处理,就会触发ANR警告[^1]。 - **BroadcastReceiver组件**:当此类组件接收广播消息后的执行时间超过了10秒钟,则会引发ANR提示。 - **Service服务调用**:对于长时间运行的服务,在其首次创建时若花费的时间超出20秒也会导致ANR情况的发生。 上述情形通常是因为当前正在处理的任务要么完全没有得到机会被执行,要么虽然已经开始但因为计算量过大或其他因素而未能迅速结束[^3]。 #### 导致ANR的具体场景 除了以上提到的时间限制外,还有几种常见的情况可能导致ANR: - 进行复杂的图形渲染或者大量的DOM操作; - 执行网络请求、文件读写等I/O密集型工作; - 处理大规模数据集或是进行深度嵌套循环等高负载CPU运算; - 错误地将耗时较长的操作放在了主线程中而不是异步方式下进行; 这些问题都可能使得UI线程陷入忙碌状态,从而影响到整个应用对外界输入做出即时反馈的能力[^4]。 #### 解决方案建议 为了避免ANR问题并提高用户体验质量,可以采取如下措施来优化代码逻辑和架构设计: - 将任何潜在的大规模计算移至后台线程(如通过`AsyncTask`, `Thread`, 或者使用更现代的选择如Kotlin协程),确保不会阻塞主线程; ```kotlin CoroutineScope(Dispatchers.IO).launch { // 耗时操作... } ``` - 对于需要频繁更新UI的内容,考虑采用分页加载策略减少一次性展示的数据量; - 使用高效算法代替低效实现以加快处理速度; - 定期监控性能指标并通过工具链诊断瓶颈所在位置以便针对性改进; - 利用Logcat记录详细的调试信息帮助定位实际发生的错误点,并据此调整业务流程使之更加流畅稳定[^2]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值