應(yīng)用模型解讀

2024-01-25 12:12 更新

HarmonyOS應(yīng)用模型概況

隨著系統(tǒng)的演進發(fā)展,HarmonyOS先后提供了兩種應(yīng)用模型:

  • FA(Feature Ability)模型:HarmonyOS早期版本開始支持的模型,已經(jīng)不再主推。

  • Stage模型:HarmonyOS 3.1 Developer Preview版本開始新增的模型,是目前主推且會長期演進的模型。在該模型中,由于提供了AbilityStage、WindowStage等類作為應(yīng)用組件和Window窗口的“舞臺”,因此稱這種應(yīng)用模型為Stage模型。

Stage模型之所以成為主推模型,源于其設(shè)計思想。Stage模型的設(shè)計基于如下出發(fā)點。

  1. 為復(fù)雜應(yīng)用而設(shè)計

    • 多個應(yīng)用組件共享同一個ArkTS引擎(運行ArkTS語言的虛擬機)實例,應(yīng)用組件之間可以方便的共享對象和狀態(tài),同時減少復(fù)雜應(yīng)用運行對內(nèi)存的占用。
    • 采用面向?qū)ο蟮拈_發(fā)方式,使得復(fù)雜應(yīng)用代碼可讀性高、易維護性好、可擴展性強。
  2. 支持多設(shè)備和多窗口形態(tài)

    應(yīng)用組件管理和窗口管理在架構(gòu)層面解耦:

    • 便于系統(tǒng)對應(yīng)用組件進行裁剪(無屏設(shè)備可裁剪窗口)。

    • 便于系統(tǒng)擴展窗口形態(tài)。

    • 在多設(shè)備(如桌面設(shè)備和移動設(shè)備)上,應(yīng)用組件可使用同一套生命周期。

  3. 平衡應(yīng)用能力和系統(tǒng)管控成本

    Stage模型重新定義應(yīng)用能力的邊界,平衡應(yīng)用能力和系統(tǒng)管控成本。

    • 提供特定場景(如卡片、輸入法)的應(yīng)用組件,以便滿足更多的使用場景。
    • 規(guī)范化后臺進程管理:為保障用戶體驗,Stage模型對后臺應(yīng)用進程進行了有序治理,應(yīng)用程序不能隨意駐留在后臺,同時應(yīng)用后臺行為受到嚴格管理,防止惡意應(yīng)用行為。

通過對比認識FA模型與Stage模型

Stage模型與FA模型最大的區(qū)別在于:Stage模型中,多個應(yīng)用組件共享同一個ArkTS引擎實例;而FA模型中,每個應(yīng)用組件獨享一個ArkTS引擎實例。因此在Stage模型中,應(yīng)用組件之間可以方便的共享對象和狀態(tài),同時減少復(fù)雜應(yīng)用運行對內(nèi)存的占用。Stage模型作為主推的應(yīng)用模型,開發(fā)者通過它能夠更加便利地開發(fā)出分布式場景下的復(fù)雜應(yīng)用。

可通過如下對比表格了解兩種模型的整體概況。

表1 FA模型與Stage模型差異概覽

項目

FA模型

Stage模型

應(yīng)用組件

1. 組件分類

 - PageAbility組件:包含UI界面,提供展示UI的能力。詳細介紹請參見PageAbility組件概述

- ServiceAbility組件:提供后臺服務(wù)的能力,無UI界面。詳細介紹請參見ServiceAbility組件概述。

- DataAbility組件:提供數(shù)據(jù)分享的能力,無UI界面。詳細介紹請參見DataAbility組件概述。

2. 開發(fā)方式

通過導(dǎo)出匿名對象、固定入口文件的方式指定應(yīng)用組件。開發(fā)者無法進行派生,不利于擴展能力。

1. 組件分類

 - UIAbility組件:包含UI界面,提供展示UI的能力,主要用于和用戶交互。詳細介紹請參見UIAbility組件概述

- ExtensionAbility組件:提供特定場景(如卡片、輸入法)的擴展能力,滿足更多的使用場景。詳細介紹請參見ExtensionAbility組件

2. 開發(fā)方式

采用面向?qū)ο蟮姆绞?,將?yīng)用組件以類接口的形式開放給開發(fā)者,可以進行派生,利于擴展能力。

進程模型

有兩類進程:

1. 主進程

2. 渲染進程

詳細介紹請參見進程模型。

有三類進程:

1. 主進程

2. ExtensionAbility進程

3. 渲染進程

詳細介紹請參見進程模型。

線程模型

1. ArkTS引擎實例的創(chuàng)建

一個進程可以運行多個應(yīng)用組件實例,每個應(yīng)用組件實例運行在一個單獨的ArkTS引擎實例中。

2. 線程模型

每個ArkTS引擎實例都在一個單獨線程(非主線程)上創(chuàng)建,主線程沒有ArkTS引擎實例。

3. 進程內(nèi)對象共享:不支持。

詳細介紹請參見線程模型

1. ArkTS引擎實例的創(chuàng)建

一個進程可以運行多個應(yīng)用組件實例,所有應(yīng)用組件實例共享一個ArkTS引擎實例。

2. 線程模型

ArkTS引擎實例在主線程上創(chuàng)建。

3. 進程內(nèi)對象共享:支持。

詳細介紹請參見線程模型

應(yīng)用配置文件

使用config.json描述應(yīng)用信息、HAP信息和應(yīng)用組件信息。

詳細介紹請參見應(yīng)用配置文件概述(FA模型)。

使用app.json5描述應(yīng)用信息,module.json5描述HAP信息、應(yīng)用組件信息。

詳細介紹請參見應(yīng)用配置文件概述(Stage模型)

以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號