Android 使用 Debug.startMethodTracing 分析方法耗时

参考 Generate Trace Logs by Instrumenting Your App

官网提供了 trace 工具来分析方法耗时。

生成 trace 文件

package com.test.luodemo.trace;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.os.Debug;
import android.util.Log;

import com.test.luodemo.R;

public class DebugActivity extends AppCompatActivity {

    public static final String TAG = "DebugActivity";

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //save to ./data/media/0/Android/data/com.test.luodemo/files/dmtrace.trace
        Debug.startMethodTracing();
        setContentView(R.layout.activity_debug);
        test1();
        test2();
        Debug.stopMethodTracing();
    }

    private void test1(){
        Log.d(TAG, "test1");
    }
    
    /**
     * 模拟耗时方法
     * */
    private void test2(){
        try {
            Thread.sleep(500);
        } catch (InterruptedException e) {
            throw new RuntimeException(e);
        }
    }
}
  • Debug.startMethodTracing(); 启动方法跟踪 。不传参数,默认生成 ./data/media/0/Android/data/<应用包名>/files/dmtrace.trace
  • Debug.stopMethodTracing(); 停止方法跟踪。

Debug.startMethodTracing() 可以传入参数,示例,加个时间戳

    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //save to ./data/media/0/Android/data/com.test.luodemo/files/dmtrace.trace
        //Debug.startMethodTracing();

        SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy_MM_dd_HH_mm_ss", Locale.getDefault());
        String logDate = dateFormat.format(new Date());
        Debug.startMethodTracing("luoah-" + logDate);

        setContentView(R.layout.activity_debug);
        test1();
        test2();
        Debug.stopMethodTracing();
    }

生成文件
在这里插入图片描述

trace 文件分析

在 AS 里打开 Device Explorer ,找到生成路径,双击生成的 dmtrace.trace 文件,
在这里插入图片描述
很明显,test2() 方法耗时 500毫秒。

相关推荐

  1. MySQL自增ID耗尽探究:分析与解决方案

    2024-07-12 11:48:03       65 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-12 11:48:03       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-12 11:48:03       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-12 11:48:03       58 阅读
  4. Python语言-面向对象

    2024-07-12 11:48:03       69 阅读

热门阅读

  1. IOS热门面试题一

    2024-07-12 11:48:03       24 阅读
  2. IOS热门面试题二

    2024-07-12 11:48:03       21 阅读
  3. Flink 任务启动常用命令

    2024-07-12 11:48:03       24 阅读
  4. 【Linux Git入门】Git的介绍

    2024-07-12 11:48:03       22 阅读
  5. 【git命令大全】

    2024-07-12 11:48:03       24 阅读
  6. 代付是什么意思呢

    2024-07-12 11:48:03       23 阅读
  7. 初阶数据结构(顺序表的实现)

    2024-07-12 11:48:03       25 阅读
  8. 一键优雅为Ubuntu20.04服务器挂载新磁盘

    2024-07-12 11:48:03       18 阅读
  9. ubuntu22.04 编译freetype动态库

    2024-07-12 11:48:03       22 阅读
  10. Uniapp 使用 Leaflet

    2024-07-12 11:48:03       26 阅读
  11. 使用Python绘制旭日图

    2024-07-12 11:48:03       23 阅读
  12. Qt/QML学习-GridView

    2024-07-12 11:48:03       19 阅读