【Android】perfetto使用学习

在开发者选项中的系统跟踪里抓取的perfetto文件是保存在/data/local/traces 里的

adb pull /data/local/traces ./

主线程中的执行是受vsync信号控制的,即间隔调用的

如果写一个while线程,一直使用cpu,是怎样的呢,这里我们来试验一下,加深学习

在一个按钮中开启一个线程

java 复制代码
new Thread(new Runnable() {
    @Override
    public void run() {
        running = true;
        int a = 222;
        int b = 11;
        Log.w("test222", "===== thread run");
        while (running) {
            try {
                // 执行一些任务
                a *= b;
            } catch (Exception e) {

                break; // 如果线程被中断,退出循环
            }
        }

    }
}).start();

执行,打印log

10-27 19:53:37.546 26783 27095 W test222 : ===== thread run

查看其trace

可以看到,这个进程号,线程号和log中的是一致的

点击Thread后面的箭头,会跳转到线程那里

可以看到,这个线程是绿色的,状态是running,一直在运行

参考资料

https://zhuanlan.zhihu.com/p/142675982

一款Android性能分析神器!Perfetto(建议收藏)_跟踪_其他系统_数据

相关推荐
z200509302 分钟前
【linux学习】linux的基本指令
linux·学习
AOwhisky28 分钟前
Docker 学习笔记:镜像分发、容器运行与资源限制
笔记·学习·docker
JohnnyDeng941 小时前
Android 包体积优化:R8/ProGuard 深度配置
android
qq_452396231 小时前
第六篇:《JMeter逻辑控制器:循环、条件和交替执行》
android·java·jmeter
MediaTea1 小时前
人工智能通识课:机器学习之无监督学习
人工智能·深度学习·学习·机器学习
Fanfanaas2 小时前
2026 年 华中杯 数学建模竞赛 A 题 问题一个人解析
学习·数学建模
cwzqf3 小时前
Jectpack Compose项目组件代码分享(1):分页加载组件
android
@北海怪兽3 小时前
SQL常见函数整理 _ STRING_AGG()
android·数据库·sql
霑潇雨3 小时前
Spark学习基础转换算子案例(单词计数(WordCount))
java·大数据·分布式·学习·spark·maven
eastyuxiao4 小时前
数字孪生教程(软件篇)官方学习路径
大数据·人工智能·学习·数字孪生