Android系统的启动时间

  

这里所说的安卓系统的启动时间,并不是简单地用秒表和肉眼来统计,而是通过分析系统输出的日志信息来统计,这样才显得更加专业,准确。


<强>首先了解2个概念:


(1) Android是基于Linux内核的系统,因此Android的启动过程是分为两个阶段的,第一个阶段就是Linux内核的启动,第二个阶段就是Android框架的启动(包括核心服务和程序)。


(2) Android   的日志系统是独立于Linux内核的日志系统的.Linux内核通过printk打印的日志信息,这些日志写入到了/dev/kmsg文件中,在   壳牌终端可以通过dmesg命令查看这些日志信息.Android框架则是通过记录器驱动打印日志信息,这些日志并没有归并到   kmesg文件中,而是单独存储的,位于/dev/日志目录下,在壳牌终端可以通过logcat命令来查看。


下面我们分别从两种日志信息中找到如何统计系统启动时间的方法。


<强> 1。,通过dmesg信息统计系统启动时间


首先,我们通过dmesg命令抓取Linux内核的日志信息(部分系统可能需要先执行亚行根):



Linux内核启动完成,一般都有如下的标准输出信息:



因此,只要我们在dmesg。txt文件中找到这一行即可,从上面的日志可以看的出,Linux内核启动只用了。


<强>那么,如何找到Android系统启动完成的标志呢?


很多Android设备在系统启动完成后,会在内核测井中打印如下信息:



因此,找到这一行也就得到了整个系统的启动时间了,从这一行可以看的出,整个系统启动用了29.913726秒。


当然,并不是所有的Android设备都会打印出这条日志,因此,我们一般用下面介绍的方法来专门统计Android系统的启动时间,


<强> 2。,通过logcat统计系统的启动时间


文章开头我们已经介绍过,Android的日志系统是独立于Linux内核测井系统的,通过在终端输入亚行壳进入Android系统,cd到/dev/日志目录,你会发现里面有四个文件,分别是:事件,主要的广播系统。


Android系统把日志分为了四类,不同的类别记录不同的日志信息:


主-主要的日志信息,大部分应用级别的日志信息都在这里

事件——系统事件相关的日志信息

广播,——无线/电话相关的日志信息

系统——低级别的系统调试日志信息


默认通过logcat抓取的是主要的信息,如果想抓取指定类别的日志信息的方法,在logcat命令后加- b参数,例如:

,adb  logcat  -d  -v  time  -b “主要”,,,祝辞,main.txt   ,adb  logcat  -d  -v  time  -b “事件”,祝辞,events.txt   ,adb  logcat  -d  -v  time  -b “系统”,祝辞,system.txt   ,adb  logcat  -d  -v  time  -b “广播”,,祝辞,广播。txt

<>强那么,如何统计Android系统的启动时间呢?


我们可以重点关注事件类别的日志信息,通过如下命令:



如图所示,这是我在高通的msm8953开发板上抓取的日志信息:


 Android系统的启动时间


代表着Android屏幕点亮,开始显示启动动画,即15.492秒开始闪烁Android字样。


代表着整个系统启动结束,即用了29.986秒,用这个总时间减去Linux内核的启动时间即可得到Android OS部分的时间。



Android系统的启动时间