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