Android系统架构与系统源码目录

前言

技术博客终于可以恢复正常的更新速度了,原因是我编写的进阶书籍的初稿已经完成,窃以为它将会是Android应用书籍中最有深度的一本,可以说是《Android开发艺术探索》的姊妹篇。在这本书的最后一章我会分析Android底层源码,但是毕竟是一本Android应用开发的书,对于底层源码阅读也只能带大家入个门。因此,在博客中我会新开一个“系统源码解析”的系列,该系列的开篇就是本篇文章。

1.Android系统架构

Android系统架构分为五层,从上到下依次是应用层、应用框架层、系统运行库层、硬件抽象层和Linux内核层。

应用层

系统内置的应用程序以及非系统级的应用程序都是属于应用层。负责与用户进行直接交互,通常都是用Java进行开发的。

应用框架层(Java Framework)

应用框架层为开发人员提供了可以开发应用程序所需要的API,我们平常开发应用程序都是调用的这一层所提供的API,当然也包括系统的应用。这一层的是由Java代码编写的,可以称为Java Framework。下面来看这一层所提供的主要的组件。

名称

功能描述

Activity Manager(活动管理器)

管理各个应用程序生命周期以及通常的导航回退功能

Location Manager(位置管理器)

提供地理位置以及定位功能服务

Package Manager(包管理器)

管理所有安装在Android系统中的应用程序

Notification Manager(通知管理器)

使得应用程序可以在状态栏中显示自定义的提示信息

Resource Manager(资源管理器)

提供应用程序使用的各种非代码资源,如本地化字符串、图片、布局文件、颜色文件等

Telephony Manager(电话管理器)

管理所有的移动设备功能

Package Manager(包管理器)

管理所有安装在Android系统中的应用程序

Window Manager(窗口管理器)

管理所有开启的窗口程序

Content Providers(内容提供器)

使得不同应用程序之间可以共享数据

View System(视图系统)

构建应用程序的基本组件

表1

系统运行库层(Native)

系统运行库层分为两部分,分别是C/C++程序库和Android运行时库。下面分别来介绍它们。

1.C/C++程序库

C/C++程序库能被Android系统中的不同组件所使用,并通过应用程序框架为开发者提供服务,主要的C/C++程序库如下表2所示。

名称

功能描述

OpenGL ES

3D绘图函数库

Libc

从BSD继承来的标准C系统函数库,专门为基于嵌入式Linux的设备定制

Media Framework

多媒体库,支持多种常用的音频、视频格式录制和回放。

SQLite

轻型的关系型数据库引擎

SGL

底层的2D图形渲染引擎

SSL

安全套接层,是为网络通信提供安全及数据完整性的一种安全协议

FreeType

可移植的字体引擎,它提供统一的接口来访问多种字体格式文件

表2

2.Android运行时库

运行时库又分为核心库和ART(5.0系统之后,Dalvik虚拟机被ART取代)。核心库提供了Java语言核心库的大多数功能,这样开发者可以使用Java语言来编写Android应用。相较于JVM,Dalvik虚拟机是专门为移动设备定制的,允许在有限的内存中同时运行多个虚拟机的实例,并且每一个Dalvik 应用作为一个独立的Linux 进程执行。独立的进程可以防止在虚拟机崩溃的时候所有程序都被关闭。而替代Dalvik虚拟机的ART 的机制与Dalvik 不同。在Dalvik下,应用每次运行的时候,字节码都需要通过即时编译器转换为机器码,这会拖慢应用的运行效率,而在ART 环境中,应用在第一次安装的时候,字节码就会预先编译成机器码,使其成为真正的本地应用。

硬件抽象层(HAL)

硬件抽象层是位于操作系统内核与硬件电路之间的接口层,其目的在于将硬件抽象化,为了保护硬件厂商的知识产权,它隐藏了特定平台的硬件接口细节,为操作系统提供虚拟硬件平台,使其具有硬件无关性,可在多种平台上进行移植。 从软硬件测试的角度来看,软硬件的测试工作都可分别基于硬件抽象层来完成,使得软硬件测试工作的并行进行成为可能。通俗来讲,就是将控制硬件的动作放在硬件抽象层中。

Linux内核层

Android 的核心系统服务基于Linux 内核,在此基础上添加了部分Android专用的驱动。系统的安全性、内存管理、进程管理、网络协议栈和驱动模型等都依赖于该内核。 Android系统的五层架构就讲到这,了解以上的知识对以后分析系统源码有很大的帮助。

2.Android系统源码目录

我们要先了解Android系统源码目录,为后期源码学习打下基础。关于源码的阅读,你可以访问http://androidxref.com/来阅读系统源码。当然,最好是将源码下载下来。下载源码可以使用清华大学开源软件镜像站提供的Android 镜像:https://mirrors.tuna.tsinghua.edu.cn/help/AOSP/ 。如果觉得麻烦也可以查找国内的网盘进行下载,推荐使用该百度网盘地址下载:http://pan.baidu.com/s/1ngsZs,它提供了多个Android版本的的源码下载。

整体结构

各个版本的源码目录基本是类似,如果是编译后的源码目录会多增加一个out文件夹,用来存储编译产生的文件。Android7.0的根目录结构说明如下表所示。

Android源码根目录

描述

abi

应用程序二进制接口

art

全新的ART运行环境

bionic

系统C库

bootable

启动引导相关代码

build

存放系统编译规则及generic等基础开发包配置

cts

Android兼容性测试套件标准

dalvik

dalvik虚拟机

developers

开发者目录

development

应用程序开发相关

device

设备相关配置

docs

参考文档目录

external

开源模组相关文件

frameworks

应用程序框架,Android系统核心部分,由Java和C++编写

hardware

主要是硬件抽象层的代码

libcore

核心库相关文件

libnativehelper

动态库,实现JNI库的基础

ndk

NDK相关代码,帮助开发人员在应用程序中嵌入C/C++代码

out

编译完成后代码输出在此目录

packages

应用程序包

pdk

Plug Development Kit 的缩写,本地开发套件

platform_testing

平台测试

prebuilts

x86和arm架构下预编译的一些资源

sdk

应用程序包

packages

sdk和模拟器

system

底层文件系统库、应用和组件

toolchain

工具链文件

tools

工具文件

Makefile

全局Makefile文件,用来定义编译规则

表3

从表3可以看出,系统源码分类清晰,并且内容庞大且复杂。接下来分析packages中的内容,也就是应用层部分。

应用层部分

应用层位于整个Android系统的最上层,开发者开发的应用程序以及系统内置的应用程序都是在应用层。源码根目录中的packages目录对应着系统应用层。它的目录结构如表4所示。

packages目录

描述

apps

核心应用程序

experimental

第三方应用程序

inputmethods

输入法目录

providers

内容提供者目录

screensavers

屏幕保护

services

通信服务

wallpapers

墙纸

表4

从目录结构可以发现,packages目录存放着系统核心应用程序、第三方的应用程序和输入法等等,这些应用都是运行在系统应用层的,因此packages目录对应着系统的应用层。

应用框架层部分

应用框架层是系统的核心部分,一方面向上提供接口给应用层调用,另一方面向下与C/C++程序库以及硬件抽象层等进行衔接。 应用框架层的主要实现代码在/frameworks/base和/frameworks/av目录下,其中/frameworks/base目录结构如表5所示。

/frameworks/base目录

描述

/frameworks/base目录

描述

api

定义API

cmds

重要命令:am、app_proce等

core

核心库

data

字体和声音等数据文件

docs

文档

graphics

图形图像相关

include

头文件

keystore

和数据签名证书相关

libs

location

地理位置相关库

media

多媒体相关库

native

本地库

nfc-extras

NFC相关

obex

蓝牙传输

opengl

2D/3D 图形API

packages

设置、TTS、VPN程序

sax

XML解析器

services

系统服务

telephony

电话通讯管理

test-runner

测试工具相关

tests

测试相关

tools

工具

wifi

wifi无线网络

表5

C/C++程序库部分

系统运行库层(Native)中的 C/C++程序库的类型繁多,功能强大,C/C++程序库并不完全在一个目录中,这里给出几个常用且比较重要的C/C++程序库所在的目录位置。

目录位置

描述

bionic/

Google开发的系统C库,以BSD许可形式开源。

/frameworks/av/media

系统媒体库

/frameworks/native/opengl

第三方图形渲染库

/frameworks/native/services/surfaceflinger

图形显示库,主要负责图形的渲染、叠加和绘制等功能

external/sqlite

轻量型关系数据库SQLite的C++实现

表6

讲完 C/C++程序库部分,剩下的部分我们在表3已经给出:Android运行时库的代码放在art/目录中。硬件抽象层的代码在hardware/目录中,这一部分是手机厂商改动最大的一部分,根据手机终端所采用的硬件平台会有不同的实现。

原文发布于微信公众号 - 刘望舒(liuwangshuAndroid)

原文发表时间:2017-01-23

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏iOS 开发杂谈

iOS如何使用TestFlight进行App Beta版测试

TestFlight的测试方式分为两种: 一种是内部测试; 一种是外部测试。 从功能上讲,这两种方式都可以为测试人员在测试阶段对你的App进行测试。但是既...

1.3K20
来自专栏互联网开发者交流社区

SEO-搜索引擎高级搜索指令

18350
来自专栏.Net移动开发

4.6预告先导篇——你们关心的几个问题:关于页、文档、内网推送等

非常感谢大家对Smobiler的支持,从4.6版本的建议征集中,整理了几个大家关注得比较多的问题,在此单独列出答复。

14220
来自专栏Android机动车

安卓优化之apk瘦身(27.7M-->17.5M)

apk瘦身作为优化的一部分,它的大小决定安装的时间与占用的内存,进行针对性的瘦身也能够提高用户体验,下面就看我怎样将一个27.7M的安装包减肥到17.5M,足足...

12540
来自专栏葡萄城控件技术团队

渐进式Web应用程序的深入概述

如果您是Web开发人员,您可能已经了解渐进式Web应用程序(PWA)或已经实现了自己的应用程序。 如果您不熟悉,本文将深入概述渐进式Web应用程序的实现原理,以...

8920
来自专栏ThoughtWorks

无法登录的用户

自从ins项目上线以后,团队其他成员都纷纷下了项目,只留下他这个项目经理留在一线解决问题。登录这块总是出现问题,上次就出现过一次,不过上次是机房网络原因,而这次...

13310
来自专栏逸鹏说道

Web前端性能优化教程01:减少Http请求和使用内容分发网络

性能黄金法则 只有10%-20%的最终用户响应时间花在接收请求的HTML文档上,剩下的80%-90%时间花在HTML文档所引用的所有组件(图片,script,c...

44270
来自专栏DevOps时代的专栏

微服务之基于Docker的分布式企业级实践

35330
来自专栏冰霜之地

手把手教你利用Jenkins持续集成iOS项目

众所周知,现在App的竞争已经到了用户体验为王,质量为上的白热化阶段。用户们都是很挑剔的。如果一个公司的推广团队好不容易砸了重金推广了一个APP,好不容易有了一...

17730
来自专栏FreeBuf

利用QRLJacking工具获取Whatsapp帐号权限

这篇文章将会教你如何用 QRLJacking 去获取别人 Whatsapp 帐号的权限,这种攻击是交互式,需要受害者去扫描你搭建好的钓鱼网站里面的恶意二维码,或...

22020

扫码关注云+社区

领取腾讯云代金券