关于Android的架构是四层还是五层,没有唯一的正确答案。两种说法都对,它们只是看待同一套复杂系统的不同"颗粒度",这种差异本身也反映了Android系统的设计演变。
具体的分层对比如下:
📜 两种主流分层方案对照


| 层级 | 🅰️ 四层模型 (宏观视角) | 🅱️ 五层模型 (精确视角) |
|---|---|---|
| 第5层 (顶层) | 应用程序层 (Application) | 应用程序层 (Application) |
| 第4层 | 应用程序框架层 (Application Framework) | 应用程序框架层 (Application Framework) |
| 第3层 | 系统运行库层 (Libraries & Android Runtime) | 系统运行库层 (Libraries & Android Runtime) |
| 第2层 | (此层被合并) | 硬件抽象层 (HAL) |
| 第1层 (底层) | Linux内核层 (Linux Kernel) | Linux内核层 (Linux Kernel) |
其中每一层都包含大量的子模块或子系统:
-
应用程序层 (顶层):这是用户直接打交道的软件,包括系统内置的桌面、电话、短信应用,也包括我们自己安装的所有App。
-
应用程序框架层 (第4层):这一层主要为开发者提供了一整套构建App所需的API,并负责管理组件生命周期、提供各类资源、通知等。
-
系统运行库层 (第3层):它分为两部分:一部分是C/C++原生库(如媒体库、WebKit、SQLite等);另一部分是Android Runtime(ART),负责运行应用的字节码。
-
硬件抽象层 (第2层,五层独有) :这是两种分法的核心区别。它将底层复杂的驱动程序细节进行封装,向上层提供统一的标准接口,同时也允许厂商提供闭源驱动,保护了知识产权的需求。
-
Linux内核层 (底层):这是整个Android系统的基石,基于Linux内核,负责最基础的内存管理、进程管理、网络协议栈和各种硬件驱动。
🤔 为何存在两种分法?
-
视角不同 :在Android早期(约2007-2010年),官方文档常以四层 结构示人,让开发者更关注应用逻辑。而随着Android系统发展,硬件抽象层的战略意义越来越重要,因此官方开始突出五层结构,并以此作为标准的参考架构。
-
"碎片化"治理 :长期以来,因厂商无法及时更新驱动,导致新系统难以快速适配旧设备,即"Android碎片化"。为解决此问题,谷歌在Android 8.0中推出 Project Treble 项目,将硬件抽象层(HAL) 与系统框架彻底解耦,让厂商驱动的更新不再受限于系统更新。这就让五层架构从一种"可选项"变成了谷歌官方力推的"必选项"。
💎 总结
简单来说,四层是历史视角,五层是官方定论。今天当我们讨论现代Android系统架构时,五层模型是更主流的选择。不过,记住四层模型有助于理解最核心的软件栈划分,而五层模型则能让你更精确地把握现代Android系统的设计精髓。