App启动优化(一)冷启动和热启动
如需转载请评论或简信,并注明出处,未经允许不得转载
系列文章
目录
前言
启动速度是一个app对用户来说的第一体验,如果启动速度慢就会给用户的第一印象不太好,这里我们可以参考”八秒定律“
八秒定律是在互联网领域存在的一个定律,即指用户访问一个网站时,如果等待网页打开的时间超过8秒,会有超过70%的用户放弃等待
本系列文章将进行App启动优化相关讲解,本节我们先来了解一下App启动的分类
启动分类
冷启动
当启动应用时,后台没有该应用的进程,这时系统会重新创建一个新的进程分配给该应用,这个启动方式就是冷启动
大致流程
当点击app的启动图标后,首先会通过AMS在System进程展示一个Starting Window(通常情况下是个白屏,可以通过设置Application的theme修改),接着AMS会通过Zygote创建应用程序的进程,并通过一系列的步骤后调用Application的attachBaseContext()
、onCreate()
然后最终调用Activity的onCreate()/onStart/onResume
以及contentView
的measure/layout/draw
最终显示在界面上
冷启动耗时最多,是app启动时长的衡量标准
热启动
在后台已有进程的情况下,系统会从已有的进程中来启动应用,这个方式叫热启动(例:按back键、home键,应用虽然会退出,但是该应用的进程是依然会保留在后台,可进入任务列表查看)。热启动因为会从已有的进程中来启动,所以热启动就不会走Application
这步了,而是直接走MainActivity
(包括一系列的测量、布局、绘制),所以热启动的过程只需要创建和初始化一个MainActivity
就行了,而不必创建和初始化Application
。显然热启动比冷启动更快
参考文档:App startup time
总结
本文介绍了了冷启动和热启动以及它们对应的启动流程,在明白了流程之后我们才能有针对性的对各个步骤进行优化,从而加快启动时间