捕获 Macrobenchmark 的各项指标

指标是指从基准测试中提取的主要信息类型。这些指标会以 List 的形式传递给 measureRepeated 函数;也就是说,您可以一次性指定多个测量指标。若要运行基准测试,必须至少提供一种类型的指标。

以下代码段会捕获帧时间和自定义的轨迹部分指标。

Kotlin

benchmarkRule.measureRepeated(
    packageName = TARGET_PACKAGE,
    metrics = listOf(
        FrameTimingMetric(),
        TraceSectionMetric("RV CreateView"),
        TraceSectionMetric("RV OnBindView"),
    ),
    // ...
)

Java

benchmarkRule.measureRepeated(
    /* packageName */ TARGET_PACKAGE,
    /* metrics */ Arrays.asList(
        new StartupTimingMetric(),
        new TraceSectionMetric("RV CreateView"),
        new TraceSectionMetric("RV OnBindView"),
    ),
    /* iterations */ 5,
    // ...
);

基准测试结果会输出到 Android Studio,如下图所示。 如果定义了多个指标,则所有这些指标会在输出中合并到一处。

TraceSectionMetric 和 FrameTimingMetric 的结果

StartupTimingMetric

StartupTimingMetric 可使用以下值捕获应用启动时间指标:

  • timeToInitialDisplayMs - 从系统收到启动 intent 到渲染目标 activity 的第一帧的时间。
  • timeToFullDisplayMs - 从系统收到启动 intent 到通过 reportFullyDrawn 方法完整绘制应用报告的时间。当跟随在 reportFullyDrawn() 调用之后(或包含该调用)的第一帧完成渲染时,测量即会停止。Android 10(API 级别 29)及更低版本可能不支持此测量功能。

如需详细了解影响应用启动时间的各个因素,请查看应用启动时间页面。

StartupTimingMetric 结果

FrameTimingMetric

FrameTimingMetric 会捕获基准测试所生成帧(如滚动或动画)的时间信息,并输出以下值:

  • frameOverrunMs - 给定帧错过其截止时间多长时间。正数表示丢帧和可见的卡顿,负数表示帧比其截止时间早多少时间结束。仅适用于 Android 12(API 级别 31)及更高版本。
  • frameDurationCpuMs - 在 CPU(界面线程和 RenderThread)上生成帧所花费的时间。

系统会按以下分布来收集这些测量值:第 50 个、第 90 个、第 95 个和第 99 个百分位。

如需详细了解如何发现和改进渲染速度缓慢的帧,请参见渲染速度缓慢

FrameTimingMetric 结果

TraceSectionMetric(实验性)

TraceSectionMetric 会捕获与提供的 sectionName 匹配的轨迹部分所花费的时间,并输出该时间的最小值中位数最大值(以毫秒为单位)。轨迹部分是通过 trace(sectionName){} 函数调用或者 Trace.beginSection(sectionName)Trace.endSection()(或其异步变体)之间的代码来定义。该指标始终选择测量期间所捕获轨迹部分的第一个实例。

如需详细了解如何进行跟踪,请参见系统跟踪概览定义自定义事件

TraceSectionMetric 结果