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

相关推荐
液态不合群9 分钟前
一文学习 Spring 声明式事务源码全流程总结
java·学习·spring
loitawu24 分钟前
Rockchip Android16 系统裁剪指南
android·android16·android裁剪·系统裁剪·rockchip app
云边散步24 分钟前
godot2D游戏教程系列二(20)
笔记·学习·音视频
CyanMind27 分钟前
IsaacLab 训练范式探索(二):从“上帝视角”到实机落地的蒸馏学习
学习
吃个糖糖29 分钟前
Open3D学习点云读取与显示
学习
DANGAOGAO31 分钟前
Transformer学习
深度学习·学习·transformer
电子云与长程纠缠1 小时前
Godot学习04 - UI界面
学习·ui·godot
少许极端1 小时前
算法奇妙屋(三十五)-贪心算法学习之路 2
学习·算法·贪心算法
`Jay1 小时前
Python Redis连接池&账号管理池
redis·分布式·爬虫·python·学习
小羊子说1 小时前
关于车机中的升级流程小结(SOC、MCU、4G升级流程)
android·adb·性能优化·车载系统