转自:http://ticktick.blog.51cto.com/823160/1660996

本文是《Android内核开发》系列的第七篇文章,通过上一篇文章《Android内核开发:图解Android系统的启动过程》我们大致了解了Android系统的启动过程,那么本文就从实践的角度,简单介绍一下如何统计Android系统的启动时间。


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


首先了解2个概念:


(1) Android是基于Linux内核的系统,因此Android的启动过程是分为两个阶段的:

    第一个阶段就是Linux内核的启动

    第二个阶段就是Android框架的启动(包括核心服务和程序)。


(2)Android的log系统是独立于Linux内核的log系统的。

   Linux内核通过printk打印的log信息,这些log写入到了/dev/kmsg文件中,在Shell终端可以通过dmesg命令查看这些log信息。 

   Android框架则是通过Logger驱动打印log信息,这些log并没有归并到kmesg文件中,而是单独存储的,位于/dev/log目录下,在Shell终端可以通过logcat命令来查看。


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


1.  通过dmesg信息统计Linux内核启动时间


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


$ adb shell dmesg > dmesg.txt


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


<6> [ 6.613861] Freeing init memory: 176K


因此,只要我们在dmesg.txt文件中找到“Freeing init memory”这一行即可,从上面的log可以看出,Linux内核启动只用了6.613861s。


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


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


<6>[ 29.913726] init: processing action 0x96bb8 (property:sys.boot_completed=1)


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


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


2.  通过logcat统计Android Logger启动时间


文章开头我们已经介绍过,Android的log系统是独立于Linux内核log系统的,通过在终端输入adb shell 进入Android系统,cd到/dev/log目录,你会发现里面有四个文件,分别是:events,main,radio,system.


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


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

events - 系统事件相关的Log信息

radio   - 无线/电话相关的Log信息

system - 低级别的系统调试Log信息


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


1
2
3
4
$ adb logcat -d -v time -b "main"   >  main.txt
$ adb logcat -d -v time -b "events" >  events.txt
$ adb logcat -d -v time -b "system" >  system.txt
$ adb logcat -d -v time -b "radio"  >  radio.txt


关于Android Log系统的分类,你可以访问如下页面详细了解: 《Android Logging System》


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


我们可以重点关注events类别的log信息,通过如下命令:


$ adb logcat -v time -d -b events | grep "boot"


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



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


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


3.  小结


由于本文重点关注如何统计Android系统的启动时间,因此,很多启动log文件的分析就不做详细展开了,下一篇文章将会对系统启动的log做稍微详细的分析。有任何疑问或者建议欢迎留言或者来信lujun.hust@gmail.com交流,或者关注我的新浪微博 @卢_俊 获取最新的文章和资讯。

Android内核开发:如何统计系统的启动时间相关推荐

  1. Android内核开发:学会分析系统的启动log

    本文是<Android内核开发>系列的第八篇文章,本文主要关注如何分析Android系统的启动log,学会通过搜索重要的TAG标签,找到Android启动过程中的重要节点. 要学会分析系统 ...

  2. Android内核开发:系统编译输出的镜像文件

    本文是<Android内核开发>的第四篇文章,主要介绍一下源码编译输出的几个重要的镜像文件,这里把bootloader源码和Linux内核源码的编译输出也算在其中,因为毕竟Android系 ...

  3. Android内核开发:系统启动速度优化

    在学习新知识的过程中,我一直很推荐结合实战任务去学习,只有经历实战,才能加深对理论知识的理解.<Android内核开发>系列已经写了八篇了,本文就结合前面的内容,给大家布置一个实战任务:  ...

  4. Android内核开发:图解Android系统的启动过程

    本文是<Android内核开发>系列的第六篇文章,前面的几篇文章介绍了Android内核开发相关的基础知识,包括:Android源码的下载.版本和分支介绍.编译和烧写等等,从本文起就要开始 ...

  5. Android内核开发:系统分区与镜像文件的烧写

    本文是<Android内核开发>系列的第五篇文章,本文重点介绍如何把编译输出的镜像文件烧写到Android设备中. 玩过刷机的朋友肯定对fastboot这个工具并不陌生,它是Android ...

  6. Android内核开发:为什么刷机后系统第一次启动会很慢?

    转自:http://ticktick.blog.51cto.com/823160/1677216 在做Android内核开发的过程中,我们会发现,每次编译完系统源码,烧录到设备/手机中后,第一次启动都 ...

  7. Android内核开发:源码的版本与分支详解

    我想很多初学者或许跟我一样,看完Android源码下载相关的文章以后,就开始兴致勃勃地去下载Android源码了,但是下载完了源码后,有没有像我一样产生如下几个困惑呢? (1) Android版本有哪 ...

  8. Android内核开发:从源码树中删除出厂的app应用

    本文是<Android内核开发>系列的第十一篇文章,本文重点介绍如何从Android源码中删除出厂的app应用. 上一篇文章中提到过,系统出厂的app应用,其实就是被安装到/system分 ...

  9. Android内核开发:理解和掌握repo工具

    由于Android源码是用repo工具来管理的,因此,搞Android内核开发,首先要搞清楚repo是什么东西,它该怎么使用?作为<Android内核开发>系列文章的第二篇,我们首先谈谈对 ...

最新文章

  1. 8.0强行转换后变成了7_【自学C#】|| 笔记 12 数据类型转换
  2. Object.wait()与Object.notify()的用法
  3. 【09】Nginx:静态压缩 / 日志切割 / 防盗链 /恶意解析/ 跨域
  4. html获取文件路径_HTML 文件路径
  5. 学编程怎样入门?这是最有效的学习方法
  6. 漫画:博弈论系列 之 囚徒困境
  7. Oracle--替代触发器(INSTEAD OF)
  8. 基于C#程序触摸屏软件盘开发总结
  9. 疯狂Android讲义(第2版)
  10. 深度学习的显卡对比评测:2080ti vs 3090 vs A100
  11. 计算机在智能建筑中的应用,【计算机技术在建筑智能化中的应用研究原稿_0材料】...
  12. 【得物技术】如何测试概率性事件 - 二项分布置信区间
  13. IOS技术分享| 互动连麦场景实现
  14. 开关、按钮开关、自锁开关内部结构
  15. 三天让车跑起来!stm32循迹车 —— 第一天:基本模块使用方法
  16. 华为小世界杯来了:从一棵树到一片森林的大赛
  17. OpenStack读书笔记
  18. 关于3B大战那点事儿
  19. 河南省焦作市谷歌高清卫星地图下载
  20. 很经典话,随便一句都可以当做QQ签名

热门文章

  1. Hammer.js分析(四)——recognizer.js
  2. 使用Pls_Integer的好处
  3. android中getSystemService详解
  4. java createcell_CreateCell
  5. 的clear会清空内存吗_Python内存分配时有哪些不为你知的小秘密?
  6. 仿各大app的商品详情页购买信息弹幕
  7. java project保存_java project 导出介绍
  8. abaqus切削为什么没有切屑_金属高速切削的ABAQUS仿真(下)
  9. idea怎么给方法快速添加注释_生完孩子胸部下垂怎么办?来看快速矫正的方法
  10. matlab求任意点最短路径,【最短路】求两点间最短路径的改进的Dijkstra算法及其matlab实现...