1 启动状态 1.1冷启动 启动需要5s 或更长时间 冷启动是指应用从头开始启动,系统进程在冷启动后才创建应用进程 第一次启动应用 1.2热启动 启动需要1.5s 或更长时间 在热启动中,系统的所有工作就是将Activity带到前台只要应用的所有Activity仍驻留在内存中,应用就不要重复 执行对象初始化,布局加载和绘制的流程 1.3温启动 启动需要2s 或更长时间 温启动包含了在冷启动期间发生的部分操作,同时,同时,他的开销要比热启动高,有许多潜在的状态视为温启动 例如 #用户在退出应用后又重新启动应用,进程可能未被销毁,继续运行,但应用需要执行onCreate()从头开始重新创建Activity 2 adb shell 通过命令行链接手机,需要配置adb 环境变量 am start -S -W com.xxx.xxx/.MainActivity -S 停止应用, -W 启动应用 WaitTime 包括前一个应用Activity pause 的时间和新应用启动的时间 ThisTime 表示一连串启动Activity的最后一个Activity的启动耗时 TotalTime 表示新应用启动的耗时,包括新进程的启动和Activity的启动,但不包括前一个activity pause 的耗时 启动时间统计到MainActivity的onWindowFocusChanged()方法 Application onCreate()中的耗时操作 使用工具 CPU Profile 1 android studio 顶部app 选中Edit Configurations Sample Java Methods 采样模式 Trace Java Methods 跟踪模式 1 使用异步加载xml
new AsyncLayoutInfater
Implementation “androidx.asynclayoutinflater:asynclayoutinflater:1.0.0”
2 可以在Application 中编辑严苛模式
启动页白屏处理
<style name="AppTheme.StartingWindowTheme" parent="AppTheme">
<item name="android:windowBackground">@drawable/startingwindow_bg</item>
<item name="android:windowFullscreen">true</item>
</style>
<layer-list xmlns:android="http://schemas.android.com/apk/res/andrioid">
<item android:drawable="@android:color/white"/>
<item>
<bitmap
android:gravity="center"
android:scaleType="centerCrop"
android:src="@drawable/bg"/>
</item>
</layer-lsit>
<activity android:name=".MainActivity"
android:theme="@style/AppTheme.StartingWindowTheme">
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setTheme(R.style.AppTheme);
setContentView(R.layout.activity_main);
}
Debug.startMethodTracing("enjoy");
Debug.startMethodTracingSampling(new File(Environment.getExternalstorageDirectory(),"enjoy").
getAbsolutePath(),8*1024*1024,1000);
Debug.stopMethodTracing();
启动优化相关 1 合理使用异步初始化,延迟初始化,懒加载机制 2 启动过程避免耗时操作,如数据库I/O操作不要放在主线程执行 3 类加载优化,提前异步执行类加载 4 合理使用idleHandler进行延迟初始化 5 简化布局
做过的性能优化的例子 1 使用Debug.startMethodTracing 或这 andorid profile 的方式记录启动的耗时,然后分析android profile 内的数据 ,可以看出来哪些地方耗时比较严重,一些耗时比较严重的第三方库,或这自己写的代码 ,把一些能放到子线程的东西放到子线程, Android profile “ call chart ””flame char””top Down””Bottom Up” 字节mutlidex 优化, 主要的方法是,通过重写,修改了mutlidex 去掉了,dex转zip的步骤,
idleHandler 空闲的时候回调Handler
Looper.myQueue().addIdleHandler(new MessageQueue.IdleHandler(){
@Override
public boolean queueIdle(){
return false;
}
});
Systrace
Systrace是Android平台提供的一款工具,用于记录短期内的设备活动,其中汇总了Android内核中的数据,例如CPU调度程序,磁盘活动和应用程序,Systrace主要用来分析绘制性能方面的问题,在发生卡顿时,通过这份报告,可以知道当前整个系统所处的状态,从而帮助开发者更直观的分析系统瓶颈,改进系统性能`
|