APP性能优化已成为衡量中高级Android开发程序员的标准之一,所以想要突破职业瓶颈,掌握一些必要的优化技巧就很重要了。启动速度就像是你给人的第一印象,如果第一印象就是木讷,那恐怕很难受到青睐,所以优化响应速度势在必行。今天主要总结一下APP的启动优化。
目录
1.概要,简述APP启动过程。
2.优化目标,主要优化冷启动过程。
3.优化工具。
3.1.时间节点打印。
3.2.针对耗时过程进行优化。
4.小结
概要
我们知道Java应用程序的入口是main方法,但是,在Android应用程序开发都是从Activity的onCreate方法开始的,不过Android应用程序确实存在main函数,其就是ActivityThread.main方法。在main方法里,创建了应用进程,创建了Application对象和默认启动的Activity,并且开启了Handler消息循环。所以,通常所说的启动过程是指:从Application onCreate到默认Activity onCreate 的过程。这个过程根据用户的行为不同又分为热启动和冷启动,即当应用进程不存在时,启动过程成为冷启动,否则称为热启动,冷启动和热启动的速度真的是天壤之别。
优化目标
由于冷启动的过程包含了热启动过程,所以只要针对冷启动进行优化即可。需要使用优化工具获取具体的耗时步骤,再针对性的优化。
优化工具
1.应用启动时间计算命令
adb shell am start -W [包名]/[启动页]
david@bbb32:~$ adb shell am start -W a.b.c/a.b.c.StartActivity
Starting: Intent { act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] cmp=a.b.c/.StartActivity }
Status: ok
Activity: a.b.c/.StartActivity
ThisTime: 2738
TotalTime: 2738
WaitTime: 2779
Complete
david@bbb32:~$
TotalTime:应用的启动时间。包含创建进程+Application初始化+Activity初始化到界面显示。
通过此命令,我们可以得知应用启动总的耗时时间,这个将作为优化质量高低的参考值之一。
2.常规时间打点
就是在对应的方法前后打印输出日志查看具体的时间。这种办法比较基础,且对代码的修改较大,不推荐使用。
3.TraceView和SysTrace使用
TraceView是Android平台一个很好的性能分析工具,它可以通过图形化的方式让我们了解我们要跟踪的程序的性能,并且能具体到方法。
3.1通过Android studio自带的traceview查看(Android profiler)
3.2通过Android SDK自带的Debug
//在Application的onCreate方法前调用
Debug.startMethodTracing("app_start.trace");
//在默认Activity的onCreate方法前调用
Debug.stopMethodTracing();
然后在下面的目录下会生成trace文件
/sdcard/Android/data/a.b.c/files/app_start.trace
导出此文件,通过Android Studio的profile打开改文件
3.3.SysTrace使用
SysTrace用于收集可帮助您检查原生系统进程的详细系统级数据,例如CPU调度、磁盘活动、应用线程等,并解决掉帧引起的界面卡顿。
TraceCompat.beginSection("AppOnCreate");
TraceCompat.endSection();
即可以抓取到整个应用在此过程的相关信息,例如在onCreate方法中添加上述两行代码,执行相关python命令:
python systrace.py -b 32768 -t 10 -a com.xxx.xxx.browser -o browser.html sched gfx view wm am app
即可以看到添加的tag“AppOnCreate”,对应的时间信息:
Wall Duration 代表的方法从开始到结束的耗时
CPU Duration 代表CPU的执行时间
通过这两个参数可以看出此流程中执行的时间等相关信息
我们都知道CPU是轮询模式,因此优化的方向可以说是两个方向,提高CPU的核数和优化CPU执行的时间。
小结
关于时间就是尽量使用工具,关于优化整体思路就是能预加载能延迟加载的资源尽量去预加载去延迟加载,能异步的业务尽量异步。
参考文献
1.android 启动页优化_Android性能优化--启动优化
2.Android应用启动优化
3.Android studio 中traceview的使用