Android渲染优化之卡顿检测、统计fps

本文介绍了如何通过自定义`printer`和`Choreographer.FrameCallback`接口来检测和统计Android应用的卡顿与FPS。通过分析`adb shell dumpsys gfxinfo`和`looper`,实现了一种方法来记录并计算两帧之间的绘制时间间隔,当间隔超过特定阈值时,视为卡顿并进行统计。此外,还提供了`FrameSkipMonitor`的源码链接,用于实际应用中的性能监控。
摘要由CSDN通过智能技术生成

学习自

https://juejin.im/post/5a6fd7b86fb9a01ca47ac6e8


adb shell dumpsys gfxinfo

这个是一个方法,但是用的不多


从looper入手

// This must be in a local variable, in case a UI event sets the logger
final Printer logging = me.mLogging;
if (logging != null) {
    logging.println(">>>>> Dispatching to " + msg.target + " " +
            msg.callback + ": " + msg.what);
}

final long traceTag = me.mTraceTag;
if (traceTag != 0) {
    Trace.traceBegin(traceTag, msg.target.getTraceName(msg));
}
try {
    msg.target.dispatchMessage(msg);
} finally {
    if (traceTag != 0) {
        Trace.traceEnd(traceTag);
    }
}

if (logging != null) {
    logging.println("<<<<< Finished to " + msg.target + " " + msg.callback);
}
可以看到msg的执行前后都有log,所以我们只要拿到前后log的时间差就可以拿到我们msg执行的时间了(视图绘
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值