HarmonyOS 鸿蒙Next ArkTS语言教程入门学习第29天,应用模型的构成要素及应用模型解读。

发布于 1周前 作者 zlyuanteng 来自 鸿蒙OS

HarmonyOS 鸿蒙Next ArkTS语言教程入门学习第29天,应用模型的构成要素及应用模型解读。

应用模型的构成要素

应用模型是HarmonyOS为开发者提供的应用程序所需能力的抽象提炼,它提供了应用程序必备的组件和运行机制。有了应用模型,开发者可以基于一套统一的模型进行应用开发,使应用开发更简单、高效。

HarmonyOS应用模型的构成要素包括:

  • 应用组件

    应用组件是应用的基本组成单位,是应用的运行入口。用户启动、使用和退出应用过程中,应用组件会在不同的状态间切换,这些状态称为应用组件的生命周期。应用组件提供生命周期的回调函数,开发者通过应用组件的生命周期回调感知应用的状态变化。应用开发者在编写应用时,首先需要编写的就是应用组件,同时还需编写应用组件的生命周期回调函数,并在应用配置文件中配置相关信息。这样,操作系统在运行期间通过配置文件创建应用组件的实例,并调度它的生命周期回调函数,从而执行开发者的代码。

  • 应用进程模型

    应用进程模型定义应用进程的创建和销毁方式,以及进程间的通信方式。

  • 应用线程模型

    应用线程模型定义应用进程内线程的创建和销毁方式、主线程和UI线程的创建方式、线程间的通信方式。

  • 应用任务管理模型

    应用任务管理模型定义任务(Mission)的创建和销毁方式,以及任务与组件间的关系。HarmonyOS应用任务管理由系统应用负责,三方应用无需关注,下文不做具体介绍。

  • 应用配置文件

    应用配置文件中包含应用配置信息、应用组件信息、权限信息、开发者自定义信息等,这些信息在编译构建、分发和运行阶段分别提供给编译工具、应用市场和操作系统使用。

应用模型解读

HarmonyOS应用模型概况

随着系统的演进发展,HarmonyOS先后提供了两种应用模型:

  • FA(Feature Ability)模型:HarmonyOS早期版本开始支持的模型,已经不再主推。

  • Stage模型:HarmonyOS 3.1 Developer Preview版本开始新增的模型,是目前主推且会长期演进的模型。在该模型中,由于提供了AbilityStage、WindowStage等类作为应用组件和Window窗口的“舞台”,因此称这种应用模型为Stage模型。

Stage模型之所以成为主推模型,源于其设计思想。Stage模型的设计基于如下出发点。

  • 为复杂应用而设计

    • 多个应用组件共享同一个ArkTS引擎(运行ArkTS语言的虚拟机)实例,应用组件之间可以方便的共享对象和状态,同时减少复杂应用运行对内存的占用。
    • 采用面向对象的开发方式,使得复杂应用代码可读性高、易维护性好、可扩展性强。
  • 支持多设备和多窗口形态

    • 应用组件管理和窗口管理在架构层面解耦:
      • 便于系统对应用组件进行裁剪(无屏设备可裁剪窗口)。
      • 便于系统扩展窗口形态。
      • 在多设备(如桌面设备和移动设备)上,应用组件可使用同一套生命周期。
  • 平衡应用能力和系统管控成本

    • Stage模型重新定义应用能力的边界,平衡应用能力和系统管控成本。
    • 提供特定场景(如卡片、输入法)的应用组件,以便满足更多的使用场景。
    • 规范化后台进程管理:为保障用户体验,Stage模型对后台应用进程进行了有序治理,应用程序不能随意驻留在后台,同时应用后台行为受到严格管理,防止恶意应用行为。

通过对比认识FA模型与Stage模型

Stage模型与FA模型最大的区别在于:Stage模型中,多个应用组件共享同一个ArkTS引擎实例;而FA模型中,每个应用组件独享一个ArkTS引擎实例。因此在Stage模型中,应用组件之间可以方便的共享对象和状态,同时减少复杂应用运行对内存的占用。Stage模型作为主推的应用模型,开发者通过它能够更加便利地开发出分布式场景下的复杂应用。

可通过如下对比表格了解两种模型的整体概况。

表1 FA模型与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模型)

更多关于HarmonyOS 鸿蒙Next ArkTS语言教程入门学习第29天,应用模型的构成要素及应用模型解读。的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html

2 回复

在HarmonyOS鸿蒙Next中,应用模型是开发应用的基础框架,它定义了应用的结构和行为。应用模型的构成要素主要包括以下几个方面:

  1. Ability:Ability是应用的基本组成单元,代表应用的一个功能模块。Ability分为Page Ability和Service Ability。Page Ability用于展示用户界面,Service Ability用于后台服务。

  2. AbilitySlice:AbilitySlice是Page Ability的组成部分,用于管理页面的不同部分或功能。一个Page Ability可以包含多个AbilitySlice,每个AbilitySlice负责处理特定的用户交互或业务逻辑。

  3. Intent:Intent用于在Ability之间传递数据和启动Ability。通过Intent,开发者可以实现不同Ability之间的通信和跳转。

  4. Lifecycle:Lifecycle定义了Ability的生命周期,包括创建、启动、暂停、恢复、停止和销毁等状态。开发者可以通过重写生命周期回调方法来管理Ability的状态变化。

  5. Configuration:Configuration用于管理应用的配置信息,如语言、屏幕方向、字体大小等。开发者可以通过Configuration来动态调整应用的显示和行为。

  6. Task:Task是应用的任务栈,用于管理Ability的启动顺序和返回逻辑。通过Task,开发者可以控制应用的导航和返回行为。

应用模型的解读主要围绕这些构成要素展开,开发者需要理解每个要素的作用和相互关系,才能有效地构建和管理应用。通过合理设计Ability和AbilitySlice,使用Intent进行通信,管理Lifecycle和Configuration,以及控制Task的导航逻辑,开发者可以创建出结构清晰、功能完善的应用。

更多关于HarmonyOS 鸿蒙Next ArkTS语言教程入门学习第29天,应用模型的构成要素及应用模型解读。的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


在HarmonyOS鸿蒙Next中,ArkTS语言的应用模型主要由以下几个核心要素构成:

  1. UI组件:负责用户界面的展示与交互,如按钮、文本框等。
  2. 状态管理:通过@State@Prop等装饰器管理组件的状态变化。
  3. 生命周期:包括onCreateonDestroy等,管理组件的创建与销毁。
  4. 事件处理:通过@Watch@Observed等装饰器监听和处理用户交互事件。
  5. 数据绑定:实现UI与数据的双向绑定,确保数据变化时UI自动更新。

应用模型的核心在于通过组件化、状态管理和事件驱动,构建高效、可维护的应用架构。理解这些要素有助于开发者更好地设计和实现复杂的应用逻辑。

回到顶部
AI 助手
你好,我是IT营的 AI 助手
您可以尝试点击下方的快捷入口开启体验!