《Android 平台架构系统启动流程详解》

news2025/3/12 19:43:44

目录

一、平台架构模块

1.1 Linux 内核 

1.2 硬件抽象层 (HAL) 

1.3 Android 运行时 

1.4 原生 C/C++ 库 

1.5 Java API 框架 

1.6 系统应用 

二、系统启动流程

2.1 Bootloader阶段

2.2 内核启动

2.3 Init进程(PID 1)

2.4 Zygote与System Server

2.5 系统就绪与用户界面

2.6 优化与安全机制

三、关键分区与故障处理

四、总结

五、常见误解澄清


一、平台架构模块

Android 是一个基于 Linux 的开源软件堆栈,针对多种不同设备类型打造。图 1 显示了 Android 平台的主要组件。

1.1 Linux 内核 

Android 平台的基础是 Linux 内核。例如,Android 运行时 (ART) 依赖 Linux 内核来实现底层功能,例如线程处理和低级内存管理。

使用 Linux 内核可让 Android 利用关键安全功能,并让设备制造商能够为知名内核开发硬件驱动程序。

1.2 硬件抽象层 (HAL) 

硬件抽象层 (HAL) 提供了用于向较高级别的 Java API 框架公开设备硬件功能的标准接口。HAL 由多个库模块组成,每个模块都为特定类型的硬件组件(例如相机或蓝牙模块)实现一个接口。当框架 API 发出调用以访问设备硬件时,Android 系统将为该硬件组件加载库模块。

**硬件抽象层(HAL)**通过标准接口实现了硬件能力与Java框架的解耦。其核心价值体现在:

  • 模块化设计:每个硬件组件(如蓝牙、传感器)对应独立.so库

  • 动态加载机制:当应用调用Camera API时,系统自动加载对应的Camera HAL模块

  • 版本兼容:通过HIDL接口定义语言保证跨版本兼容性

这种设计使得OEM厂商可以灵活实现硬件功能,同时保持应用层API的稳定性。

1.3 Android 运行时 

对于搭载 Android 5.0(API 级别 21)或更高版本的设备,每个应用都在其自己的进程中运行,并且有其自己的 Android 运行时 (ART) 实例。ART 编写为通过执行 Dalvik 可执行文件格式 (DEX) 文件,在低内存设备上运行多个虚拟机。DEX 文件是一种专为 Android 设计的字节码格式,针对最小的内存占用量进行了优化。构建工具(如 d8)可将 Java 源代码编译成 DEX 字节码,此类字节码可在 Android 平台上运行。

ART 的部分主要功能包括:

  • 预先 (AOT) 和即时 (JIT) 编译
  • 优化的垃圾回收 (GC)
  • 在 Android 9(API 级别 28)及更高版本中,可将应用软件包的 DEX 文件转换为更紧凑的机器代码
  • 可提供更好的调试支持,包括专用采样剖析器、详细的诊断异常和崩溃报告,以及设置观察点以监控特定字段的能力

在 Android 版本 5.0(API 级别 21)之前,Dalvik 是 Android 运行时。如果您的应用在 ART 上运行良好,那么它也可以在 Dalvik 上运行,但反过来不一定。

Android 还包含一套核心运行时库,可提供 Java API 框架所使用的 Java 编程语言中的大部分功能,包括一些 Java 8 语言功能。

从Dalvik到ART的演进标志着Android性能的质的飞跃:

特性DalvikART
编译方式JIT即时编译AOT预先编译
内存占用较高优化减少40%
启动速度较慢提升50%以上
GC效率暂停时间较长并发标记清除

ART运行时的关键技术创新:

  • 支持Java 8 Lambda表达式

  • 引入Compact DEX格式减少安装体积

  • 诊断工具支持内存泄漏检测

  • 多Dex文件并行加载加速冷启动

1.4 原生 C/C++ 库 

许多核心 Android 系统组件和服务(如 ART 和 HAL)都是从需要用 C 和 C++ 编写的原生库的原生代码构建的。Android 平台提供 Java 框架 API,用于向应用提供其中一些原生库的功能。例如,您可以通过 Android 框架的 Java OpenGL API 访问 OpenGL ES,以支持在应用中绘制和操控 2D 和 3D 图形。

如果开发的是需要 C 或 C++ 代码的应用,可以使用 Android NDK 直接从原生代码访问某些原生平台库。

1.5 Java API 框架 

您可通过以 Java 语言编写的 API 使用 Android 操作系统的整个功能集。这些 API 是创建 Android 应用所需的构建块的基础,可简化核心、模块系统组件和服务的重复使用,包括以下组件和服务:

  • 丰富且可扩展的视图系统,可用于构建应用界面,包括列表、网格、文本框、按钮,甚至可嵌入的网络浏览器
  • 资源管理器,用于访问非代码资源,例如本地化的字符串、图形和布局文件
  • 通知管理器,可让所有应用在状态栏中显示自定义提醒
  • 一个 activity 管理器,用于管理应用的生命周期,并提供常见的导航返回堆栈
  • Content Provider,可让应用访问其他应用(例如“通讯录”应用)中的数据或共享自己的数据

开发者可以完全访问 Android 系统应用使用的相同框架 API。

1.6 系统应用 

Android 随附一套用于电子邮件、短信、日历、互联网浏览和通讯录等的核心应用。平台随附的应用与用户可以选择安装的应用一样,没有特殊状态。因此,第三方应用可以成为用户的默认网络浏览器、短信应用甚至默认键盘。但有一些例外情况,例如系统的“设置”应用。

系统应用既可用作用户体验应用,又能提供开发者可从自己的应用访问的关键功能。例如,如果您希望应用发送短信,则无需自行构建该功能。您可以改为调用已安装的短信应用,将消息发送给您指定的接收者。

二、系统启动流程

Android启动流程的大致步骤:

1. 电源启动,执行Boot ROM中的代码,加载Bootloader。

2. Bootloader加载内核和initramfs到内存。

3. 内核初始化硬件和驱动,挂载文件系统,启动init进程

4. init进程解析init.rc,启动系统服务,包括Zygote

5. Zygote启动System Server,System Server启动各种系统服务。

6. 系统服务启动完成后,启动Launcher,进入用户界面。

此流程体现了Android从硬件初始化到用户交互的完整链路,结合Linux内核与独特的Android服务设计,确保了系统的高效启动与运行。

Android系统的启动流程是一个复杂但结构化的过程,涉及多个阶段的协同工作。以下是整理后的详细流程:

2.1 Bootloader阶段

  • Boot ROM:设备上电后,执行芯片内固化的代码(Boot ROM),初始化硬件并加载第一阶段的Bootloader。

  • Bootloader:通常分为多个阶段(如Primary和Secondary),负责验证签名、加载内核和initramfs到内存。常见的Bootloader如U-Boot或厂商定制版本。

2.2 内核启动

  • Linux内核初始化:内核解压后,初始化CPU、内存、设备驱动等,挂载根文件系统(通常为ramdisk)。

  • 挂载系统分区:内核挂载/system(只读)、/data(读写)等分区,可能涉及dm-verity验证系统完整性。

2.3 Init进程(PID 1)

  • 解析init.rc脚本:执行早期初始化(如创建目录、设置权限),启动核心守护进程(ueventd、logd)。

  • 启动关键服务

    • Zygote:通过app_process启动,预加载Java核心类和资源,监听Socket等待孵化应用进程。

    • Service Manager:Binder IPC的核心管理服务。

    • SurfaceFlinger:图形合成服务,负责渲染UI。

    • Media Server:多媒体相关服务。

2.4 Zygote与System Server

  • Zygote孵化System Server:Zygote fork出System Server进程(Java层核心)。

  • System Server启动

    • Binder线程池初始化:启用跨进程通信。

    • 核心服务启动顺序

      1. Activity Manager:管理应用生命周期。

      2. Package Manager:管理应用安装与信息。

      3. Window Manager:窗口管理。

      4. Power ManagerBattery Service等其他服务。

    • 服务依赖管理:确保服务按正确顺序启动。

2.5 系统就绪与用户界面

  • Launcher启动:System Server完成后,Activity Manager启动主屏幕应用(如Launcher3)。

  • 广播通知:发送ACTION_BOOT_COMPLETED,告知应用系统启动完成。

2.6 优化与安全机制

  • 并行启动:Android 8.0+采用并行初始化服务,缩短启动时间。

  • 安全验证:Bootloader验证内核签名,dm-verity确保系统分区完整性。

三、关键分区与故障处理

  • 分区结构/boot(内核+ramdisk)、/system(系统应用)、/recovery(恢复模式)、/data(用户数据)。

  • 异常处理:启动失败时进入Recovery模式或Fastboot,进行系统修复。

四、总结

  • 第一个用户进程init 进程(PID 1)。

  • 核心作用:架起内核与用户空间的桥梁,管理所有后续进程的启动。

  • 关键文件/init 二进制文件、init.rc 配置文件。

五、常见误解澄清

  • Zygote 不是第一个用户进程:虽然 Zygote 是 Java 层应用进程的起点,但它是由 init 进程通过解析 init.rc 脚本启动的。

  • 内核线程 vs 用户进程:内核启动阶段会运行内核线程(如 kthreadd),但这些属于内核空间,不属于用户进程。

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

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

相关文章

强化学习(赵世钰版)-学习笔记(3.最优策略与贝尔曼最优方程)

这是本章在课程中的位置,属于基础工具中的最后一章,主要讨论了最优状态值(Optimal State Value)与最优策略(Optimal Policy),并介绍了对应的计算方法-贝尔曼最优方程(Bellman Optima…

六十天前端强化训练之第十一天之事件机制超详解析

欢迎来到编程星辰海的博客讲解 目录 一、事件模型演进史 1.1 原始事件模型(DOM Level 0) 1.2 DOM Level 2事件模型 1.3 DOM Level 3事件模型 二、事件流深度剖析 2.1 捕获与冒泡对比实验 2.2 事件终止方法对比 三、事件委托高级应用 3.1 动态元…

调试正常 ≠ 运行正常:Keil5中MicroLIB的“量子态BUG”破解实录

调试正常 ≠ 运行正常:Keil5中MicroLIB的“量子态BUG”破解实录——从勾选一个选项到理解半主机模式,嵌入式开发的认知升级 📌 现象描述:调试与烧录的诡异差异 在线调试时 程序正常运行 - 独立运行时 设备无响应 ! 编译过程 0 Err…

基于SpringBoot实现旅游酒店平台功能八

一、前言介绍: 1.1 项目摘要 随着社会的快速发展和人民生活水平的不断提高,旅游已经成为人们休闲娱乐的重要方式之一。人们越来越注重生活的品质和精神文化的追求,旅游需求呈现出爆发式增长。这种增长不仅体现在旅游人数的增加上&#xff0…

ArcGIS Pro中字段的新建方法与应用

一、引言 在地理信息系统(GIS)的数据管理和分析过程中,字段操作起着至关重要的作用。 无论是进行地图制作、空间分析还是数据统计,字段都是承载属性信息的基本单元。 ArcGIS Pro作为一款功能强大的GIS软件,为用户提…

c#面试题12

1.ApplicationPool介绍一下 c#里没有 2.XML 可扩展标记语言,一般以.xml文件格式的形式存在。可用于存储结构化的数据 3.ASP.NET的用户控件 将原始的控件,用户根据需要进行整合成一个新的控件 4.介绍一下code-Behind 即代码后置技术,就是…

Matlab中快速查找元素索引号

1、背景介绍 在算法设计过程中,有时候需要从一维/二维数组中,快速查找是否某个元素,以及该元素所在的位置。如一维矩阵[1 2 3 4 5 6 6 7 8]所示,元素6所在的位置为6 7。 2、函数测试 matlab中函数find()可以快速查找到指定元素所…

LabVIEW非线性拟合实现正弦波参数提取

LabVIEW的Nonlinear Curve Fit.vi基于Levenberg-Marquardt算法,能够实现非线性最小二乘拟合,包括正弦波三参数(幅值、频率、相位)的精确求解。该工具适用于非均匀采样、低信噪比信号等复杂场景,但需注意初始参数设置与…

S19文件格式详解:汽车ECU软件升级中的核心镜像格式

文章目录 引言一、S19文件格式的起源与概述二、S19文件的核心结构三、S19在汽车ECU升级中的应用场景四、S19与其他格式的对比五、S19文件实例解析六、工具链支持与安全考量七、未来趋势与挑战结语引言 在汽车电子控制单元(ECU)的软件升级过程中,S19文件(也称为Motorola S-…

Redis 缓存穿透、缓存击穿与缓存雪崩详解:问题、解决方案与最佳实践

目录 引言 1. 缓存穿透 1.1 什么是缓存穿透? 示例: 1.2 缓存穿透的原因 1.3 缓存穿透的解决方案 1.3.1 缓存空对象 1.3.2 布隆过滤器(Bloom Filter) 1.3.3 参数校验 2. 缓存击穿 2.1 什么是缓存击穿? 示例&…

Qt入门笔记

目录 一、前言 二、创建Qt项目 2.1、使用向导创建 2.2、最简单的Qt应用程序 2.2.1、main函数 2.2.2、widget.h文件 2.2.3、widget.cpp文件 2.3、Qt按键Botton 2.3.1、创建一个Botton 2.3.2、信号与槽 2.3.3、按键使用信号与槽的方法 2.4、文件Read与Write-QFile类 2…

C语言每日一练——day_4

引言 针对初学者,每日练习几个题,快速上手C语言。第四天。(连续更新中) 采用在线OJ的形式 什么是在线OJ? 在线判题系统(英语:Online Judge,缩写OJ)是一种在编程竞赛中用…

下降路径最⼩和(medium)

题目描述: 给你一个 n x n 的 方形 整数数组 matrix ,请你找出并返回通过 matrix 的下降路径 的 最小和 。 下降路径 可以从第一行中的任何元素开始,并从每一行中选择一个元素。在下一行选择的元素和当前行所选元素最多相隔一列&#xff08…

redux_旧版本

reduxjs/toolkit(RTK)是 Redux 官方团队推出的一个工具集,旨在简化 Redux 的使用和配置。它于 2019 年 10 月 正式发布,此文章记录一下redux的旧版本如何使用,以及引入等等。 文件目录如下: 步骤 安装依…

18、TCP连接三次握手的过程,为什么是三次,可以是两次或者更多吗【高频】

三次握手的过程: 第一次握手:客户端 向 服务器 发送一个 SYN(也就是同步序列编号报文),请求建立连接。随后,客户端 进入 SYN_SENT 状态;服务器收到 SYN 之后,由 LISTEN 状态变为 SYN…

Ceph(2):Ceph简介

1 Ceph简介 Ceph使用C语言开发,遵循LGPL协议开源。Sage Weil(Ceph论文发表者)于2011年创立了以Inktank公司主导Ceph的开发和社区维护。2014年Redhat收购inktank公司,并发布Inktank Ceph企业版(ICE)软件,业务场景聚焦云…

wireshark 如何关闭混杂模式 wireshark操作

Fiddler和Wireshark都是进行抓包的工具:所谓抓包就是将网络传输发送与接收的数据包进行截获、重发、编辑、转存等操作,也用来检查网络安全。抓包也经常被用来进行数据截取等。黑客常常会用抓包软件获取你非加密的上网数据,然后通过分析&#…

ChatGPT4.5详细介绍和API调用详细教程

OpenAI在2月27日发布GPT-4.5的研究预览版——这是迄今为止OpenAI最强大、最出色的聊天模型。GPT-4.5在扩大预训练和微调规模方面迈出了重要的一步。通过扩大无监督学习的规模,GPT-4.5提升了识别内容中的模式、建立内容关联和生成对于内容的见解的能力,但…

Unity DOTS从入门到精通之 自定义Authoring类

文章目录 前言安装 DOTS 包什么是Authoring1. 实体组件2. Authoring类 前言 DOTS(面向数据的技术堆栈)是一套由 Unity 提供支持的技术,用于提供高性能游戏开发解决方案,特别适合需要处理大量数据的游戏,例如大型开放世…

一键换肤的Qt-Advanced-Stylesheets

项目简介 能在软件运行时对 CSS 样式表主题(包括 SVG 资源和 SVG 图标)进行实时颜色切换的Qt项目。 项目预览: 项目地址 地址:Qt-Advanced-Stylesheets 本地编译环境 Win11 家庭中文版 Qt5.15.2 (MSVC2019) Qt Creator1…