常见现象
各种第三方工具初始化和大量业务逻辑初始化,影响启动时间,导致应用启动延迟、卡顿等现象
APP的启动流程
加载和启动应用程序;
App启动之后立即展示出一个空白的启动窗口;
创建App程序的进程;
创建App对象;
启动Main Thread;
创建启动页的Activity;
加载View;
布置屏幕;
进行初始绘制;
详细启动流程可以看这篇文章
APP启动流程
计算启动时间
看一张官图

上图是Google提供的冷启动流程图,可以看到冷启动的起始点时Application.onCreate()方法,结束点在ActivityRecord.reportLanuchTimeLocked()方法。
我们可以通过以下两种方式查看冷启动的耗时
Displayed Time
在Android 4.4(API级别19)及更高版本中,logcat包含一个名为Displayed的log信息,此值表示启动过程和完成在屏幕上绘制相应活动之间所经过的时间量。
adb logcat | grep Displayed
05-08 19:18:14.303 419 477 I ActivityTaskManager: Displayed ***/.ui.HomeActivity: +1s382ms
adb dump
adb shell am start -S -W ***/.ui.HomeActivity -c android.intent.category.LAUNCHER -a android.intent.action.MAIN
Stopping: ***
Starting: Intent {
act=android

1147

被折叠的 条评论
为什么被折叠?



