[Android性能优化篇] APP启动优化

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的使用

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容

  • 一、概述 手机桌面点击一个应用,用户希望应用能 及时响应、快速加载。启动时间过长的应用可能会令用户失望。这种糟糕的...
    胡飞洋阅读 1,336评论 3 7
  • 请保持淡定,分析代码,记住:性能很重要。 启动时间优化 毫无疑问,应用的启动速度越快越好。 本文可以帮助你优化应用...
    Mupceet阅读 11,393评论 5 19
  • 应用启动类型 冷启动场景:开机后第一次启动应用 或者 应用被杀死后再次启动生命周期:Process.start->...
    please边去阅读 2,194评论 0 2
  • 久违的晴天,家长会。 家长大会开好到教室时,离放学已经没多少时间了。班主任说已经安排了三个家长分享经验。 放学铃声...
    飘雪儿5阅读 7,518评论 16 22
  • 今天感恩节哎,感谢一直在我身边的亲朋好友。感恩相遇!感恩不离不弃。 中午开了第一次的党会,身份的转变要...
    迷月闪星情阅读 10,561评论 0 11