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

相关推荐
SUNNY_SHUN8 分钟前
ICLR 2026 | Judo: 7B小模型工业缺陷问答超越GPT-4o,用对比学习+强化学习注入领域知识
论文阅读·人工智能·学习·视觉检测·github
嗷嗷哦润橘_23 分钟前
图解PD分离分布式架构及端口配置解析
人工智能·学习·pd分离
圣光SG23 分钟前
ES6+ 基础学习笔记
笔记·学习·es6
zx_zx_12325 分钟前
红黑树的学习
学习
小陈phd41 分钟前
多模态大模型学习笔记(二十六)—— 核心技术篇③ | 虚拟人的声音情感:从语音合成到声音克隆
笔记·学习
云边散步1 小时前
godot2D游戏教程系列二(23)
笔记·学习·游戏·音视频·游戏开发
xiangxiongfly9151 小时前
Android 绘制流程源码分析
android·layout·measure·绘制流程·draw
进击的cc1 小时前
Android Kotlin:高阶函数与Lambda简化回调地狱
android·kotlin
hzb666661 小时前
xd_day32-day40
java·javascript·学习·安全·web安全·tomcat·php
1171 小时前
Android资源类型与常用的四种布局资源
android