博客
关于我
【安卓开发系列 -- 系统分析】Framework -- Android 系统一般启动流程简介
阅读量:371 次
发布时间:2019-03-04

本文共 1167 字,大约阅读时间需要 3 分钟。

【安卓开发系列 -- 系统分析】Framework -- Android 系统一般启动流程简介

【1】Android 系统的整体启动流程

概述:Loader > Kernel > Native > Framework > Application

细分:BootRom > Bootloader > Kernel > Init > Zygote > SystemServer > Launcher

Loader 层主要包括      : Boot Rom 和 Boot LoaderKernel 层主要包括      : Android 内核层Native 层主要是包括    : init 进程以及其 fork 出来的用户空间的守护进程、HAL 层、开机动画等Framework 层主要包括   : AMS 和 PMS 等 Service 的初始化Application 层主要包括 : SystemUI、Launcher 的启动

整体的启动流程图 

Bootloader 引导程序的作用,初始化硬件设备,加载内核文件;

阶段一,汇编编写,初始化基本硬件;阶段二,C语言实现,初始化 Flash 设备,设置网络、内存等,将 kernel 映像和根文件系统映像从 Flash 上读到 RAM 空间中,加快内核启动速度;

Linux 内核启动,初始化各种软硬件环境,加载驱动程序,挂载根文件系统等,内核启动完成后,会启动 init 进程从而进入 Android 系统的启动阶段;

init 进程, Linux 系统中用户空间的第一个进程,进程号为 1,可以视为其他所有进程的父进程,init 进程主要功能有 1). 文件系统;2). 提供属性服务;3). 解析 init.rc 脚本;4). 创建 Zygote 进程等;

Zygote 进程,创建 Android 中的应用进程,是 Android 系统所有应用(JAVA 进程)的父进程;

SystemServer 进程,主要的作用是启动各种系统服务,如 ActivityManagerService,PackageManagerService,WindowManagerService 以及硬件相关的服务,应用程序通过与 SystemServer 进程通讯,获取各种服务对象的句柄,从而执行相应的操作达到使用各种系统服务的目的;

Launcher,Android 启动的第一个应用程序,即桌面程序,可以通过 Launcher 启动其他的应用程序;

参考与致谢

本博客为博主学习笔记,同时参考了网上众博主的博文以及相关专业书籍,在此表示感谢,本文若存在不足之处,请批评指正。

【1】Android 系统源代码情景分析

【2】深入理解 Android 卷 II

【3】

【4】

【5】

【6】

转载地址:http://gvmr.baihongyu.com/

你可能感兴趣的文章
MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
查看>>
MYSQL中TINYINT的取值范围
查看>>
MySQL中UPDATE语句的神奇技巧,让你操作数据库如虎添翼!
查看>>
Mysql中varchar类型数字排序不对踩坑记录
查看>>
MySQL中一条SQL语句到底是如何执行的呢?
查看>>
MySQL中你必须知道的10件事,1.5万字!
查看>>
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>
mysql中出现Unit mysql.service could not be found 的解决方法
查看>>
mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
查看>>
Mysql中各类锁的机制图文详细解析(全)
查看>>
MySQL中地理位置数据扩展geometry的使用心得
查看>>
Mysql中存储引擎简介、修改、查询、选择
查看>>
Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>