ANR 学习笔记

本文详细探讨了Android ANR的工作原理,包括服务ANR的三个步骤,并提供了ANR问题的实战分析方法,涉及ANR日志分析、内存和CPU占用情况检查,以及不同类型的ANR案例分析。
摘要由CSDN通过智能技术生成

接触 ANR 分析一段时间了,但在碰到相关问题的时候,总还是有一种生涩感,专门开篇博客,做一些文章阅读后的笔记吧,不断积累。(友情提示:每个蓝色字的小标题都是一个链接,可以点击跳转到大佬的原文。)

一、理论篇

1 Android ANR 的设计原理

ANR被总结为:埋雷、拆雷、爆雷三个步骤。主要内容是结合源码,分析了 service ANR 的原理,最后的总结我直接复制一下:
1 将要执行的service添加到系统进程的executingServices中。
2 开启检测逻辑,检测将在指定时间后执行,具体时间决定与是前台服务还是后台服务。
3 一旦服务被执行完,就会尝试移除检测逻辑。
4 如果检测逻辑没被移除,就会被执行,然后去检测哪个服务发生了ANR。
5 如果发生了ANR,就将构建ANR信息提供给系统,否则就检测并执行下一轮ANR检测。

二 、实战篇

1 ANR问题该如何分析?

这篇文章极力推荐,虽然是 17 年的,但都是干货啊,想精简一下都难。主要总结了

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值