Android卡顿优化 | 卡顿单点问题监测方案

本文要点

  • 背景介绍
  • 监测指标
  • 常规方案
  • IPC问题监测技巧
  • 相对优雅的方案【ARTHook】
  • ARTHook实战
  • 小结
项目GitHub

背景介绍

  • 前面提到过两种自动化自动化检测方案:
    AndroidPerformanceMonitorANR-WatchDog

  • 需要本方案的原因:自动化卡顿检测方案无法满足所有场景;
    如,有很多Message要执行,
    但是所有Message的时间,
    都没有达到自动化卡顿检测方案所配置的卡顿的判定阈值
    那这种情况,自动化卡顿检测方案对这些“较小型”的卡顿问题便无能为力了;
    可是这些没有达到卡顿的判定阈值“较小型”的卡顿问题
    却会一直影响用户体验,这显然是不行的!!

  • 需要建立体系化的卡顿解决方案
    便要尽早地尽可能多地暴露问题,补充已有方案的不足;

  • ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
    需要关注的单点问题IPC、DB操作、IO、View绘制等;
    下面以主线程IPC为例,
    因为IPC其实是一个很耗时的操作,
    但实际开发时很多时候都没有得到足够的重视
    偶尔还会在主线程进行IPC操作,以及频繁的调用,
    而这种耗时其实很少达到卡顿的阈值
    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

监测指标

  • IPC的调用类型
    PackageManager的调用、ActivityManagerService的调用和TelephoneManager的调用就是属于不同的调用类型(不同类型的IPC操作)
  • IPC的调用耗时、次数
  • IPC的调用堆栈【哪行代码调用的】、发生线程【IPC具体发生在哪个线程】

常规方案

  • 在IPC前后加埋点
  • 缺点:不优雅,容易忘记;
       维护成本大,人员交接也麻烦;

IPC问题监测技巧

  • 【线下】adb命令
    • adb shell am trace-ipc start
      运行这行命令,可以对IPC的操作进行监控;

    • adb shell am trace-ipc stop -dump-file /data/local/tmp/ipc-trace.txt
      监控结束,并将监控到的信息存放到相对应的文件当中;

    • adb pull /data/local/tmp/ipc-trace.txt
      将文件导出;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

凌川江雪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值