1.3 架构介绍
HarmonyOS整体遵从分层架构设计,从下向上依次为:内核层、系统服务层、框架层和应用层。系统功能按照“系统 > 子系统 > 組件”逐级展开,在多设备部署场景下,支持根据实际需求裁剪某些非必要的组件。HarmonyOS技术架构如下图1-4所示。
图1-4 架构图
1.3.1 内核层
内核层主要分为两部分:
内核子系统:HarmonyOS采用多内核设计,支持针对不同资源受限设备选用适合的OS内核。内核抽象层(KAL,Kernel Abstract Layer)通过屏蔽多内核差异,对上层提供基础的内核能力,包括进程/线程管理、内存管理、文件系统、网络管理和外设管理等。如图1-5所示。
驱动子系统:硬件驱动框架(HDF)是HarmonyOS硬件生态开放的基础,提供统一外设访问能力和驱动开发、管理框架。
图1-5 内核子系统
1.3.2 系统服务层
系统服务层是HarmonyOS的核心能力集合,通过框架层对应用程序提供服务。
图1-6 系统服务层
图1-6展示了系统服务层的能力集合。该层包含以下几个部分:
系统基本能力子系统集:为分布式应用在HarmonyOS多设备上的运行、调度、迁移等操作提供了基础能力,由分布式软总线、分布式数据管理、分布式任务调度、方舟多语言运行时、公共基础库、多模输入、图形、安全、AI等子系统组成。其中,方舟运行时提供了C/C++/JS/ArkTS多语言运行时和基础的系统类库,也为使用方舟编译器静态化的Java程序(即应用程序或框架层中使用Java语言开发的部分)提供运行时。
基础软件服务子系统集:为HarmonyOS提供公共的、通用的软件服务,由事件通知、电话、多媒体、DFX(Design For X) 、MSDP&DV等子系统组成。
增强软件服务子系统集:为HarmonyOS提供针对不同设备的、差异化的能力增强型软件服务,由智慧屏专有业务、穿戴专有业务、IoT专有业务等子系统组成。
硬件服务子系统集:为HarmonyOS提供硬件服务,由位置服务、生物特征识别、穿戴专有硬件服务、IoT专有硬件服务等子系统组成。
根据不同设备形态的部署环境,基础软件服务子系统集、增强软件服务子系统集、硬件服务子系统集内部可以按子系统粒度裁剪,每个子系统内部又可以按功能粒度裁剪。
1.3.3 框架层
框架层为HarmonyOS应用开发提供了Java/C/C++/JS等多语言的用户程序框架和Ability框架,适用于Java语言的Java UI框架,适用于JS语言的ArkUI框架,以及各种软硬件服务对外开放的多语言框架API。根据系统的组件化裁剪程度,HarmonyOS设备支持的API也会有所不同。
图1-7展示了框架层所涵盖的功能。
图1-7 框架层
1.3.4 应用层
应用层包括系统应用和第三方非系统应用。HarmonyOS的应用由一个或多个FA(Feature Ability)或PA(Particle Ability)组成。其中,FA有UI界面,提供与用户交互的能力;而PA无UI界面,提供后台运行任务的能力以及统一的数据访问抽象。基于FA/PA开发的应用,能够实现特定的业务功能,支持跨设备调度与分发,为用户提供一致、高效的应用体验。
如下图1-8展示的是一个视频通话应用的组成情况。
图1-8 视频通话应用的组成
在一个视频通话应用中,往往会有一个作为视频通话的主界面FA,和若干个PA组成。FA提供UI界面用于与用户进行交互,PA1用于摄像头视频采集,PA2用于视频美颜处理,PA3用于超级夜景处理。这些FA、PA可以按需下载、加载和运行。
图1-9展示了不同设备下载相同应用时的不同表现。当手机下载该应用时,将同时拥有FA主界面、PA1摄像头视频采集、PA2视频美颜处理、PA3超级夜景处理;而当智慧屏下载该应用时,如果智慧屏不支持视频美颜处理、超级夜景处理功能时,则只会下载FA主界面、PA1摄像头视频采集。
图1-9 不同设备下载相同应用时的不同表现
参考资料
《跟老卫学HarmonyOS开发》 开源免费教程,https://github.com/waylau/harmonyos-tutorial
《鸿蒙HarmonyOS手机应用开发实战》(清华大学出版社)
“鸿蒙系统实战短视频App 从0到1掌握HarmonyOS”(https://coding.imooc.com/class/674.html)
《鸿蒙HarmonyOS应用开发入门》(清华大学出版社)
“2024鸿蒙零基础快速实战-仿抖音App开发(ArkTS版)”(https://coding.imooc.com/class/843.html)
《鸿蒙HarmonyOS应用开发从入门到精通战(第2版)》(北京大学出版社)
《鸿蒙之光HarmonyOS NEXT原生应用开发入门》(清华大学出版社)