【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(建议收藏)_跟踪_其他系统_数据

相关推荐
JeffDingAI7 分钟前
【CANN训练营】在CANN8.5上体验Hello World开启Ascend C学习
c语言·开发语言·人工智能·学习
d111111111d9 分钟前
STM32 HAL库定时器PWM输出全攻略:从零到精准控制
笔记·stm32·单片机·嵌入式硬件·学习
李艺为17 分钟前
Android 16安兔兔分辨率作假显示(非修改TextView方案)
android
hssfscv18 分钟前
Javaweb学习笔记——JDBC和Mybatis
笔记·学习·mybatis
裴云飞20 分钟前
Compose原理二之GapBuffer
android·架构
·云扬·21 分钟前
MySQL规范建表:从结构设计到性能优化的实践指南
android·mysql·性能优化
羊小猪~~22 分钟前
数据库学习笔记(十八)--事务
数据库·笔记·后端·sql·学习·mysql
Heynchy31 分钟前
ThreadLocal分析简介【Android学习】
android·学习
医工交叉实验工坊41 分钟前
2026国自然改版后,该如何写
学习
●VON42 分钟前
DeepSeek-V3.2 模型在 OpenJiuWen 中的部署实践
学习·华为·von·openjiuwen