当前位置: 首页 > news >正文

安卓ANR检测、分析、优化面面谈

前言

一个引发讨论的楔子,以下三种现象有什么区别:

  • App停止运行
  • App暂无响应
  • App闪退
    答案:
    产生原因不同:
  • 停止运行是UNCheckException+Error
  • 暂无响应是ANRDialog
  • 闪退是CheckException+Error
    本文讨论的主题是ANR的定义、分类、复现、分析、优化。

ANR定义

Application Not Responding

ANR类型

Input dispatching timed out

按键或触摸事件在特定时间内无响应(origin:5s)
KEY_DISPATCHING_TIMEOUT = 8*1000

12-08 10:51:08.136 763-787/system_process E/ANRManager: ANR in com.xx(com.xx/com.xxactivity.ScreenSaverPicSelectActivity), time=26867631Reason: Input dispatching timed out (Waiting to send non-key event because the touched window has not finished processing certain input events that were delivered to it over 500.0ms ago.  Wait queue length: 36.  Wait queue head age: 8510.1ms.)

Broadcast Timeout

BroadcastReceiver在特定时间内无法处理完成
BROADCAST_FG_TIMEOUT: 10s
BROADCAST_BG_TIMEOUT: 60s
按键和广播事件时间内未响应,时间限定定义在ActivityManagerService.java类中

Service Timeout

Service在特定的时间内无法处理完成,属于小概率类型
service时间内未响应时间限定在ActiveServices.java类中
SERVICE_TIMEOUT = 20*1000;

Activity Timeout

名称 时间
Activity#onPause 500ms
Activity#onStop 10s

Activity#onDestory	10s12-08 17:22:11.296 719-743/system_process W/ActivityManager: 
Activity stop timeout for ActivityRecord{2fd135ba u0 com.xx./com.unilife.fridge.home.banner.OpenFullScreenActivity t206}

ANR原因

  1. 应用进程有一个主线程(main thread)和一个信息队列(main message queue) main thead == activity thread
  2. 主线程负责处理像Draw、Listen、receive等UI事件
  3. 主线程负责从消息队列中取出信息并分发它
  4. 主线程在完成当前信息处理之前,不会再取信息队列中的信息
  5. 如果主线程在处理当前信息时卡住,没有及时分发,ANR就会出现

ANR检测

ANR检测工具

http://www.lryc.cn/news/360089.html

相关文章:

  • “手撕”链表的九道OJ习题
  • 解决 Git commit 或 Git merge 跑到 VIM 里面去了
  • 营造科技展厅主题氛围,多媒体应用有哪些新策略?
  • 【UML用户指南】-04-从代码到UML的关键抽象
  • (2024,LoRA,全量微调,低秩,强正则化,缓解遗忘,多样性)LoRA 学习更少,遗忘更少
  • 【Java】面向对象的三大特征:封装、继承、多态
  • 请问Java8进阶水平中,常用的设计模式有哪些?
  • 力扣--最大子数组和
  • C# 中的字符与字符串
  • TPM之VMK密封
  • Fastjson 反序列化漏洞[1.2.24-rce]
  • 【面试宝藏】Go基础面试题其一
  • python如何安装pyqt4
  • 调用上传文件接口出现格式错误
  • leetcode148. 排序链表,归并法,分治的集大成之作
  • 一维时间序列信号的小波模极大值分解与重建(matlab R2018A)
  • 五分钟“手撕”栈
  • MAC也能玩转3A大作 Crossover使用指南 crossover运行战地5
  • docker私有镜像仓库的搭建及认证
  • simCSE句子向量表示(1)-使用transformers API
  • 网络运维的重要性
  • 还不会使用多线程优化代码执行效率?codefun教你在业务场景中使用CompletableFuture进行优化!
  • 数据结构-堆(带图)详解
  • React Native 之 react-native-share(分享)库 (二十三)
  • JCR一区级 | Matlab实现TCN-BiGRU-MATT时间卷积双向门控循环单元多特征分类预测
  • 游戏心理学Day01
  • 错误模块路径: ...\v4.0.30319\clr.dll,v4.0.30319 .NET 运行时中出现内部错误,进程终止,退出代码为 80131506。
  • 005 CentOS 7.9 RabbitMQ安装及配置
  • Xcode 15 libarclite 缺失问题
  • 绘画智能体分享