Stage模型与FA模型
FA 模型:Feature Ability,API 8及其更早版本的应用程序只能使用FA模型进行开发。FA模型将Ability分为FA(Feature Ability)和PA(Particle Ability)两种类型,其中FA支持Page Ability,PA支持Service Ability、Data Ability、以及FormAbility。 关于这个模型,HarmonyOS早期版本支持的模型,已经不再主推
Stage模型:从API 9(HarmonyOS 3.1 Developer Preview)版本开始新增的模型,是目前主推且会长期演进的模型。在该模型中,由于提供了AbilityStage、WindowStage等类作为应用组件和Window窗口的“舞台”,因此称这种应用模型为Stage模型。
模型对比
华为官方描述
| 项目 | FA模型 | Stage模型 |
|---|---|---|
| 应用组件 | 1. 组件分类 - PageAbility组件:包含UI界面,提供展示UI的能力。详细介绍请参见PageAbility组件概述。 - ServiceAbility组件:提供后台服务的能力,无UI界面。详细介绍请参见ServiceAbility组件概述。 - DataAbility组件:提供数据分享的能力,无UI界面。详细介绍请参见DataAbility组件概述。 2. 开发方式通过导出匿名对象、固定入口文件的方式指定应用组件。开发者无法进行派生,不利于扩展能力。 | 1. 组件分类 - UIAbility组件:包含UI界面,提供展示UI的能力,主要用于和用户交互。详细介绍请参见UIAbility组件概述。 - ExtensionAbility组件:提供特定场景(如卡片、输入法)的扩展能力,满足更多的使用场景。详细介绍请参见ExtensionAbility组件。 2. 开发方式采用面向对象的方式,将应用组件以类接口的形式开放给开发者,可以进行派生,利于扩展能力。 |
| 进程模型 | 有两类进程: 1. 主进程 2. 渲染进程详细介绍请参见进程模型。 | 有三类进程: 1. 主进程 2. ExtensionAbility进程 3. 渲染进程详细介绍请参见进程模型。 |
| 线程模型 | 1. ArkTS引擎实例的创建一个进程可以运行多个应用组件实例,每个应用组件实例运行在一个单独的ArkTS引擎实例中。 2. 线程模型每个ArkTS引擎实例都在一个单独线程(非主线程)上创建,主线程没有ArkTS引擎实例。 3. 进程内对象共享:不支持。详细介绍请参见线程模型。 | 1. ArkTS引擎实例的创建一个进程可以运行多个应用组件实例,所有应用组件实例共享一个ArkTS引擎实例。 2. 线程模型ArkTS引擎实例在主线程上创建。 3. 进程内对象共享:支持。详细介绍请参见线程模型。 |
| 应用配置文件 | 使用config.json描述应用信息、HAP信息和应用组件信息。详细介绍请参见应用配置文件概述(FA模型)。 | 使用app.json5描述应用信息,module.json5描述HAP信息、应用组件信息。详细介绍请参见应用配置文件概述(Stage模型)。 |
对于开发者
| 对比 | FA模型 | Stage模型 |
|---|---|---|
| 开发方式 | 提供类Web的API,UI开发与Stage模型一致。 | 提供面向对象的开发方式,UI开发与FA模型一致。 |
| 引擎实例 | 每个进程内的每个Ability实例独享一个JS VM引擎实例。 | 每个进程内的多个Ability实例共享一个JS VM引擎实例。 |
| 进程内对象共享 | 不支持。 | 支持。 |
| 包描述文件 | 使用config.json描述HAP包和组件信息,组件必须使用固定的文件名。 | 使用module.json5描述HAP包和组件信息,可以指定入口文件名。 |
| 组件 | 提供PageAbility(页面展示),ServiceAbility(服务),DataAbility(数据分享)以及FormAbility(卡片)。 | 提供Ability(页面展示)、Extension(基于场景的服务扩展)。 |
Ability类型存在差异
Ability生命周期存在差异