1# 应用模型 2 3<!--Kit: Ability Kit--> 4<!--Subsystem: Ability--> 5<!--Owner: @ccllee1--> 6<!--Designer: @ccllee1--> 7<!--Tester: @lixueqing513--> 8<!--Adviser: @huipeizi--> 9 10## 应用模型的构成要素 11 12应用模型是系统为开发者提供的应用程序所需能力的抽象提炼,它提供了应用程序必备的组件和运行机制。有了应用模型,开发者可以基于一套统一的模型进行应用开发,使应用开发更简单、高效。 13 14 15应用模型的构成要素包括: 16 17 181. 应用组件 19 20 应用组件是应用的基本组成单位,是应用的运行入口。用户启动、使用和退出应用过程中,应用组件会在不同的状态间切换,这些状态称为[应用组件的生命周期](uiability-lifecycle.md)。应用组件提供生命周期的回调函数,开发者通过应用组件的生命周期回调感知应用的状态变化。应用开发者在编写应用时,首先需要编写的就是应用组件,同时还需编写应用组件的生命周期回调函数,并在应用配置文件中配置相关信息。这样,操作系统在运行期间通过配置文件创建应用组件的实例,并调度它的生命周期回调函数,从而执行开发者的代码。 21 222. 应用进程模型 23 24 应用进程模型定义应用进程的创建和销毁方式,以及进程间的通信方式。 25 263. 应用线程模型 27 28 应用线程模型定义应用进程内线程的创建和销毁方式、主线程和UI线程的创建方式、线程间的通信方式。 29 304. 应用任务管理模型(仅对系统应用开放) 31 32 应用任务管理模型定义任务(Mission)的创建和销毁方式,以及任务与组件间的关系。所谓任务,即用户使用一个应用组件实例的记录。每次用户启动一个新的应用组件实例,都会生成一个新的任务。例如,用户启动一个视频应用,此时在“最近任务”界面,将会看到视频应用这个任务,当用户点击这个任务时,系统会把该任务切换到前台,如果这个视频应用中的视频编辑功能也是通过应用组件编写的,那么在用户启动视频编辑功能时,会创建视频编辑的应用组件实例,在“最近任务”界面中,将会展示视频应用、视频编辑两个任务。 33 345. 应用配置文件 35 36 应用配置文件中包含应用配置信息、应用组件信息、权限信息、开发者自定义信息等,这些信息在编译构建、分发和运行阶段分别提供给编译工具、应用市场和操作系统使用。 37 38 39## 应用模型概况 40 41随着系统的演进发展,先后提供了两种应用模型: 42 43- FA(Feature Ability)模型:从API 7开始支持的模型,已经不再主推。 44 45- Stage模型:从API 9开始新增的模型,是目前主推且会长期演进的模型。在该模型中,由于提供了AbilityStage、WindowStage等类作为应用组件和Window窗口的“舞台”,因此称这种应用模型为Stage模型。 46 47 48## 通过对比认识FA模型与Stage模型 49 50**Stage模型与FA模型最大的区别在于**:Stage模型中,多个应用组件共享同一个ArkTS引擎实例;而FA模型中,每个应用组件独享一个ArkTS引擎实例。因此在Stage模型中,应用组件之间可以方便的共享对象和状态,同时减少复杂应用运行对内存的占用。Stage模型作为主推的应用模型,开发者通过它能够更加便利地开发出分布式场景下的复杂应用。 51 52可通过如下对比表格了解两种模型的整体概况。 53 54 **表1** FA模型与Stage模型差异概览 55 56| 项目 | FA模型 | Stage模型 | 57| -------- | -------- | -------- | 58| **应用组件** | 1. 组件分类<br/> - PageAbility组件:包含UI,提供展示UI的能力。详细介绍请参见[PageAbility组件概述](pageability-overview.md)。<br/> - ServiceAbility组件:提供后台服务的能力,无UI。详细介绍请参见[ServiceAbility组件概述](serviceability-overview.md)。<br/> - DataAbility组件:提供数据分享的能力,无UI。详细介绍请参见[DataAbility组件概述](dataability-overview.md)。<br/>2. 开发方式<br/> 通过导出匿名对象、固定入口文件的方式指定应用组件。开发者无法进行派生,不利于扩展能力。 | 1. 组件分类<br/> - UIAbility组件:包含UI,提供展示UI的能力,主要用于和用户交互。详细介绍请参见[UIAbility组件概述](uiability-overview.md)。<br/> - ExtensionAbility组件:提供特定场景(如卡片、输入法)的扩展能力,满足更多的使用场景。详细介绍请参见[ExtensionAbility组件概述](extensionability-overview.md)。<br/>2. 开发方式<br/> 采用面向对象的方式,将应用组件以类接口的形式开放给开发者,可以进行派生,利于扩展能力。 | 59| **进程模型** | 有两类进程:<br/>1. 主进程<br/>2. 渲染进程<br/>详细介绍请参见[进程模型](process-model-fa.md)。 | 有三类进程:<br/>1. 主进程<br/>2. ExtensionAbility进程<br/>3. 渲染进程<br/>详细介绍请参见[进程模型](process-model-stage.md)。 | 60| **线程模型** | 1. ArkTS引擎实例的创建<br/> 一个进程可以运行多个应用组件实例,每个应用组件实例分别运行在单独的ArkTS引擎实例中。<br/>2. 线程模型<br/> 每个ArkTS引擎实例都在一个单独线程(非主线程)上创建,主线程没有ArkTS引擎实例。<br/>3. 进程内对象共享:不支持。<br/>详细介绍请参见[线程模型](thread-model-fa.md)。 | 1. ArkTS引擎实例的创建<br/> 一个进程可以运行多个应用组件实例,所有应用组件实例共享一个ArkTS引擎实例。<br/>2. 线程模型<br/> ArkTS引擎实例在主线程上创建。<br/>3. 进程内对象共享:支持。<br/>详细介绍请参见[线程模型](thread-model-stage.md)。 | 61|<!--DelRow--> **任务管理模型** | - 每个PageAbility组件实例创建一个任务。<br/>- 任务会持久化存储,直到超过最大任务个数(根据产品配置自定义)或者用户主动删除任务。<br/>- PageAbility组件之间不会形成栈的结构。 | - 每个UIAbility组件实例创建一个任务。<br/>- 任务会持久化存储,直到超过最大任务个数(根据产品配置自定义)或者用户主动删除任务。<br/>- UIAbility组件之间不会形成栈的结构。 | 62| **应用配置文件** | 使用config.json描述应用信息、HAP信息和应用组件信息。<br/>详细介绍请参见[应用配置文件概述(FA模型)](../quick-start/application-configuration-file-overview-fa.md)。 | 使用app.json5描述应用信息,module.json5描述HAP信息、应用组件信息。<br/>详细介绍请参见[应用配置文件概述(Stage模型)](../quick-start/application-configuration-file-overview-stage.md)。 | 63