Android系统启动流程

news2024/11/14 10:27:47

Android系统完整的启动过程,从系统层次角度可分为 Linux 系统层、Android 系统服务层、Zygote进程模型三个阶段;从开机到启动 Home Launcher 完成具体的任务细节可分为七个步骤,下面就从具体的细节来解读 Android 系统完整的初始化过程。

  • Loader(加载引导程序Boot Loader)
  • Kernel(Linux内核层)
  • Native(init进程)
  • Framework(Zygote进程/SystemServer进程)
  • Application(应用层/Launcher进程)

第一阶段是Linux的启动: Bootloader,Kernel,Driver等
第二阶段是真正的Android的启动


整体流程概括为:启动BootLoader->加载系统内核->启动Init进程->启动Zygote进程->启动Runtime进程->启动本地服务->启动Home Launcher

1、按下电源键进行系统启动:
触发引导芯片,加载预定义代码,启动引导程序BootLoader

2、启动BootLoader引导程序:
它是一个Android系统启动前运行的一个小程序,用来拉起OS并运行

3、启动linux内核:
设置缓存、被保护存储器、计划列表、加载驱动、完成系统设置,设置完后会找到系统文件init.rc启动init进程

4、启动init进程:
初始化并启动属性服务,启动zygote进程

5、启动zygote进程孵化器:
创建JVM,注册JNI,创建服务端的socket,启动systemServer进程

6、启动systemServer进程:
启动binder线程池和systemServerManager,启动各种系统服务,如AMS、WMS等

7、启动Launcher:
由AMS启动,启动后会显示已安装应用的快捷图标

具体详细过程如下 :

1、启动电源以及系统启动
        当电源按下时引导芯片从预定义的地方(固化在ROM)开始执行。加载引导程序BootLoader到RAM中,然后执行。

2、引导程序BootLoader
        引导程序BootLoader是在Android操作系统开始运行前的一个小程序,它的主要作用是将AndroidOS拉起来。

3、Linux内核启动
        当内核启动时,设置缓存、被保护存储器、计划列表、加载驱动。当内核完成系统设置后,它首先会在系统文件中寻找init.rc文件,并启动init.rc进程。

4、init进程启动
        init进程启动做了很多工作,但是总的来说主要就是做了一下三件事:

        (1)创建和挂载启动所需文件目录。 

        (2)初始化和启动系统属性服务。

        (3)解析init.rc配置文件并启动Zygote进程。

5、Zygote进程启动
          创建Java虚拟机并为Java虚拟机注册JNI方法;创建服务端Socket;预加载类和资源;启动SystemServer进程;等待AMS请求创建新的应用进程。

6.、SystemServer进程启动
        创建并启动Binder线程池,这样可以和其他进程进行通信。

        创建SystemServiceManager,其用于对系统的服务进行创建、启动和生命周期的管理。

        启动系统中的各种服务。包括我们熟悉的AMS、PMS、WMS。

7、Launcher启动
        被SystemServer启动的AMS会启动Launcher,Launcher启动后会将已安装应用的图标显示在桌面上。

其流程图如下所示:

 

应用(APP)启动流程   


    1、点击启动一个App,Launcher进程采用Binder IPC向ActivityManagerService发起startActivity请求;

    2、ActivityManagerService接收到请求后,向zygote进程发送创建进程的请求;Zygote进程fork出新的子进程,即App进程;

    3、App进程通过Binder IPC向sytem_server进程发起绑定Application请求;

    4、system_server进程在收到请求后,进行一系列准备工作后,再通过binder IPC向App进程发送scheduleLaunchActivity请求;

    5、App进程的binder线程(ApplicationThread)在收到请求后,通过handler向主线程发送LAUNCH_ACTIVITY消息;

   6、主线程在收到Message后,通过发射机制创建目标Activity,并回调Activity.onCreate()等方法。

到此,App便正式启动,开始进入Activity生命周期,执行完onCreate/onStart/onResume方法,UI渲染结束后便可以看到App的主界面。

其流程图如下所示:

 

系统启动的相关疑问总结


1.简述Android 系统启动流程


当按电源键触发开机,首先会从 ROM 中预定义的地方加载引导程序 BootLoader 到 RAM 中,并执行 BootLoader 程序启动 Linux Kernel, 然后启动用户级别的第一个进程: init 进程。init 进程会解析init.rc 脚本做一些初始化工作,包括挂载文件系统、创建工作目录以及启动系统服务进程等,其中系统服务进程包括 Zygote、service manager、media 等。在 Zygote 中会进一步去启动 system_server 进程,然后在 system_server 进程中会启动 AMS、WMS、PMS 等服务,等这些服务启动之后,AMS 中就会打开 Launcher 应用的 home Activity,最终就看到了手机的 “桌面”。

2.system_server 为什么要在 Zygote 中启动,而不是由 init 直接启动呢


Zygote 作为一个孵化器,可以提前加载一些资源,这样 fork() 时基于 Copy-On-Write 机制创建的其他进程就能直接使用这些资源,而不用重新加载。比如 system_server 就可以直接使用 Zygote 中的 JNI函数、共享库、常用的类、以及主题资源。

3.为什么要专门使用 Zygote 进程去孵化应用进程,而不是让 system_server 去孵化呢?


首先 system_server 相比 Zygote 多运行了 AMS、WMS 等服务,这些对一个应用程序来说是不需要的。另外进程的 fork() 对多线程不友好,仅会将发起调用的线程拷贝到子进程,这可能会导致死锁,而system_server 中肯定是有很多线程的。

4.描述下是怎么导致死锁的


在 POSIX 标准中,fork 的行为是这样的:复制整个用户空间的数据(通常使用 copy-on-write 的策略,所以可以实现的速度很快)以及所有系统对象,然后仅复制当前线程到子进程。这里:所有父进程中别的线程,到了子进程中都是突然蒸发掉的

对于锁来说,从 OS 看,每个锁有一个所有者,即最后一次 lock 它的线程。假设这么一个环境,在 fork之前,有一个子线程 lock 了某个锁,获得了对锁的所有权。fork 以后,在子进程中,所有的额外线程都人间蒸发了。而锁却被正常复制了,在子进程看来,这个锁没有主人,所以没有任何人可以对它解锁。当子进程想 lock 这个锁时,不再有任何手段可以解开了。程序发生死锁。

5.Zygote 为什么不采用 Binder 机制进行 IPC 通信


Binder 机制中存在 Binder 线程池,是多线程的,如果 Zygote 采用 Binder 的话就存在上面说的fork() 与 多线程的问题了。其实严格来说,Binder 机制不一定要多线程,所谓的 Binder 线程只不过是在循环读取 Binder 驱动的消息而已,只注册一个 Binder 线程也是可以工作的,比如 service manager就是这样的。实际上 Zygote 尽管没有采取 Binder 机制,它也不是单线程的,但它在 fork() 前主动停止了其他线程,fork() 后重新启动了。
 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/56361.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

java计算机毕业设计基于springboot电商项目(附源码讲解)

目录 1. 用户端 1.1 主页(未登录时可以查看商品但是不可以购买) 1.2 登录(账号密码登录) 1.3 登录(手机验证码登录) 1.4 注册 1.5 查看商品详情 1.6 将商品加入购物车 1.7 在商品购物车中选中商品购买 1.8 …

Jenkins用户权限配置 (三)

平时开发会分为测试环境、生产环境,多个开发人员需要区分不同的权限。例如普通开发人员只能看到测试视图和发布测试环境,生产环境的发布则由负责把控的人员进行统一发布,所以需要在新建用户的同时也分配好权限 (一) 安装Role-based Authoriz…

基于C#的公交充值管理系统的设计与实现

项目描述 临近学期结束,还是毕业设计,你还在做C#程序网络编程,期末作业,老师的作业要求觉得大了吗?不知道毕业设计该怎么办?网页功能的数量是否太多?没有合适的类型或系统?等等。这里根据疫情当下,你想解决的问题…

利用SCRM进行精细化社群运营

有很多企业凭借私域模式获得爆发式的流量增长,但流量转化仍旧是个问题,因此企业在获得流量的同时,还要守住流量,进行精细化运营才行。 前言 近年来,私域、社群、裂变的模式已成为各行各业进行营销的主旋律&#xff0c…

【Matplotlib绘制图像大全】(八):Matplotlib使用text()添加文字标注

前言 大家好,我是阿光。 本专栏整理了《Matplotlib绘制图像大全》,内包含了各种常见的绘图方法,以及Matplotlib各种内置函数的使用方法,帮助我们快速便捷的绘制出数据图像。 正在更新中~ ✨ 🚨 我的项目环境: 平台:Windows10语言环境:python3.7编译器:PyCharmMatp…

[附源码]计算机毕业设计招聘系统Springboot程序

项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 M…

GIS工具maptalks开发手册(三)02——层级缩放工具

GIS工具maptalks开发手册(三)02——层级缩放工具 效果-层级缩放工具 代码 index.html <!DOCTYPE html> <html><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1"><title>…

[附源码]Python计算机毕业设计SSM抗新冠肺炎药品进销存管理系统(程序+LW)

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

[附源码]计算机毕业设计疫情防控管理系统Springboot程序

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

Mysql - 读写分离与读负载均衡之Maxscale

原文地址 Mysql - 读写分离与读负载均衡之Maxscale - 小豹子加油 - 博客园 maxscale会自动识别出集群的master与slave角色。所以我们可以将maxscale与mha结合起来&#xff0c;既能实现主库的故障转移&#xff0c;又能实现读写分离和从库的负载均衡。 一、概述 常见的高可用…

干货 | Burpsuite的使用tips总结

渗透测试用到Burp时候很多&#xff0c;整理了一些tips供测试时候更得心应手~ tips1:光标错位和中文显示 新版一打开容易光标错位&#xff0c;默认情况下使用字体是Courier New&#xff0c;显示不了中文。 换用Monospaced字体即可正常显示中文&#xff0c;一般这里就不会错位了…

[附源码]Python计算机毕业设计Django基于Web的绿色环保网站

项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等等。 环境需要 1.运行环境&#xff1a;最好是python3.7.7&#xff0c;…

【Matplotlib绘制图像大全】(十一):Matplotlib使用rcParams修改默认参数配置

前言 大家好,我是阿光。 本专栏整理了《Matplotlib绘制图像大全》,内包含了各种常见的绘图方法,以及Matplotlib各种内置函数的使用方法,帮助我们快速便捷的绘制出数据图像。 正在更新中~ ✨ 🚨 我的项目环境: 平台:Windows10语言环境:python3.7编译器:PyCharmMatp…

Allegro如何在PCB上开槽的三种方法操作指导

Allegro如何在PCB上开槽的三种方法操作指导 当PCB有特殊设计要求的时候,需要在PCB上开槽,Allegro支持在PCB上开槽操作,具体操作如下 以下图为例,需要在这个板框中间开槽 开方形槽 选择shape add rect命令 画在Board Geometry-outline层,type选择Unfilled 在需要开槽的…

C/C++ 动态规划 算法

动态规划算法&#xff0c;以最小的消耗解题&#xff01; 以一个走楼梯为例子展开。 假设有一个三级台阶&#xff0c;我们一次可以走一步&#xff0c;或者一次走两步&#xff0c;那么由此可知&#xff0c;一共有3中走法&#xff0c;如下图 当台阶数量少的时候&#xff0c;确实很…

MPViT : Multi-Path Vision Transformer for Dense Prediction

MPViT : Multi-Path Vision Transformer for Dense Prediction一、引言&#xff08;一&#xff09;、Vision Transformers for dense predictions&#xff08;二&#xff09;、Comparison to Concurrent work二、实现细节&#xff08;一&#xff09;、Multi-Path Vision Transf…

C#【必备技能篇】使用GDI绘制进度条的代码实现

文章目录一、使用“用户控件”生成圆环进度条的dll1、使用VS2019新建项目&#xff08;类库&#xff09;2、添加用户控件3 、用户控件PercentStar.cs源码编写二、引用dll&#xff0c;在Winform中代码实现1、新建Windows窗体应用&#xff08;.NET Framework&#xff09;2、添加引…

Java项目:ssm房屋租赁管理系统

作者主页&#xff1a;源码空间站2022 简介&#xff1a;Java领域优质创作者、Java项目、学习资料、技术互助 文末获取源码 项目介绍 本项目分为管理员与租户2种角色&#xff1a; 管理员主要功能包括&#xff1a; 登录、查看房源信息、添加房源、查看租赁情况、合同查看、看房申…

皓量科技入选《中国数字营销生态图2022版》4大赛道!

11月28日&#xff0c;由中国商务广告协会数字营销专业委员会、虎啸奖组委会及秒针营销科学院三方合作出版的《中国数字营销生态图2022版》正式发布&#xff08;以下简称生态图&#xff09;。皓量科技凭借多年深耕程序化广告领域的实力与经验&#xff0c;在全行业服务商的征集调…

Codeforces Round #752 (Div. 1) B. Moderate Modular Mode

翻译&#xff1a; 谁有两个偶数&#x1d465;和&#x1d466;。帮助他找到一个整数&#x1d45b;&#xff0c;使1≤&#x1d45b;≤2⋅1018&#xff0c;且&#x1d45b;mod&#x1d465;&#x1d466;mod&#x1d45b;。这里&#xff0c;&#x1d44e;mod&#x1d44f;表示&am…