如何用adb命令统计app冷启耗时

第一步:杀掉App,然后重启,过滤Displayed日志,找到App启动的第一个Activity;

adb logcat | grep Displayed

 

第二步:再次杀掉App,使用adb shell am start命令来启动app:

adb shell am start -S -W com.ss.android.article.news/.activity.MainActivity -c android.intent.category.LAUNCHER -a android.intent.action.MAIN

说明:

  1. com.ss.android.article.news/.activity.MainActivity就是我们在第一步得到的App冷启动的第一个Activity;
  2. -S参数:强制重启,如果没有-S参数,当MainActivity已启动时,就不会重启MainActivity;
  3. -W参数:列出启动过程中统计到的具体数据;
  4. -c 和 -a 为可选参数,可让您为 intent 指定 <category> 和 <action>

得到的结果如下:

 

  1. LaunchState表示冷、热、温启动;
  2. TotalTime表示新应用启动的耗时,包括新进程的启动和Activity的启动耗时(包括创建进程 + Application初始化 + Activity初始化到界面显示的时间),但不包括前一个应用Activity pause的耗时;
  3. WaitTime就是总的耗时,包括前一个应用Activity pause的时间和新应用启动的时间;因此,WaitTime比TotalTime稍大;
  4. 开发者一般只要关心TotalTime即可,这个时间才是自己应用真正启动的耗时。上面今日头条的冷启动耗时是574ms。
  5. 为了得到的结果更准确,可以写一个脚本重复执行am start命令,计算平均值;
<think>好的,我需要回答用户关于如何使用adb shell am start命令启动带有特定Intent Flag的Activity的问题。首先,我需要回忆一下相关的adb命令知识。记得am start命令用于启动Activity,而Intent Flags通常用于指定启动模式或其他行为。 用户的问题是关于传递Intent Flag参数,所以我需要确定正确的语法。根据之前的引用,比如引用[1]中提到adb shell am start [options] intent,而引用[3]中给出了示例结构。可能需要使用--ef或--esa这样的参数,但Intent Flags可能需要不同的选项。 查阅Android开发者文档或者相关资源,发现Intent Flags在adb命令中是通过添加特定的参数来指定的。例如,FLAG_ACTIVITY_NEW_TASK对应的值是0x10000000,所以需要在命令中使用--flag选项加上该值。 接下来,需要确保用户了解如何将十六进制的标志值转换为十进制,或者直接使用十六进制格式。另外,可能需要提供一些常见Flag的示例,比如FLAG_ACTIVITY_CLEAR_TOP或FLAG_ACTIVITY_SINGLE_TOP,并给出对应的数值。 还需要考虑多个Flags的组合,这时候需要用位或运算将各个值相加,然后在命令中传递总和。例如,同时使用NEW_TASK和CLEAR_TOP的话,需要计算它们的组合值。 最后,需要给出一个完整的示例命令,让用户能够直接复制并替换包名、Activity名和Flag值。同时提醒用户查看官方文档以获取所有可用的Flags及其对应的值,确保信息的准确性。 检查是否有遗漏的部分,比如是否需要转义字符或者特殊符号的处理。确保语法正确,参数顺序正确,并且解释清晰易懂。如果有多个引用来源,确保正确标注引用标识,如引用[1]、[2]或[3]中的相关内容。</think>通过 `adb shell am start` 命令启动 Activity 并传递 IntentFlag 参数时,需使用 `--flag` 选项指定标志的十六进制或十进制值。以下是具体方法: --- ### **1. 基本语法** ```bash adb shell am start --flag <FLAG值> -n <包名>/<Activity全类名> ``` - **`--flag`**:用于添加 IntentFlag 参数,后接标志的数值(十进制或十六进制格式)。 - **`-n`**:指定目标 Activity 的包名和类名[^3]。 --- ### **2. 常见 IntentFlag 值** | 标志名 | 十六进制值 | 十进制值 | |---------------------------|------------------|------------| | `FLAG_ACTIVITY_NEW_TASK` | 0x10000000 | 268435456 | | `FLAG_ACTIVITY_CLEAR_TOP` | 0x04000000 | 67108864 | | `FLAG_ACTIVITY_SINGLE_TOP`| 0x20000000 | 536870912 | --- ### **3. 示例命令** #### **场景 1:启动 Activity 并新建任务栈** ```bash adb shell am start --flag 0x10000000 -n com.example.app/.MainActivity # 或使用十进制值 adb shell am start --flag 268435456 -n com.example.app/.MainActivity ``` #### **场景 2:组合多个 IntentFlag** 若需同时传递 `FLAG_ACTIVITY_NEW_TASK` 和 `FLAG_ACTIVITY_CLEAR_TOP`,需将它们的值相加: ```bash adb shell am start --flag 0x14000000 -n com.example.app/.MainActivity # 等效于 0x10000000 (NEW_TASK) + 0x04000000 (CLEAR_TOP) ``` --- ### **4. 调试技巧** - 添加 `-W` 参数可测量 Activity 启动耗时[^2]: ```bash adb shell am start -W --flag 0x10000000 -n com.example.app/.MainActivity ``` - 使用 `dumpsys activity intents` 查看 Intent 详细信息。 --- ### **5. 注意事项** - IntentFlag 值需根据实际需求查询 [Android 官方文档](https://developer.android.com/reference/android/content/Intent)。 - 若需传递额外参数(如 `--es` 或 `--ei`),需在 `--flag` 后添加[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值