1# Stage Model Overview 2 3## Design Ideas 4 5The stage model is designed to provide a better application development mode in the distributed environment. 6 7The following figure shows the design ideas of the stage model. 8 9![stagedesign](figures/stagedesign.png) 10 11The stage model is designed based on the following considerations: 12 13- Efficient management of application processes 14 15As the device memory becomes larger, the number of processes concurrently running in the system increases. If the number of concurrent processes reaches several hundreds, the overall power consumption and performance of the system will be adversely affected without effective management measures. To restrict the behavior of background processes, the stage model uses four measures: transient task, continuous task, agent task, and Work Scheduler task. With these measures, foreground processes will obtain guaranteed resources, thereby delivering a better user experience. 16 17- Native support for cross-device migration and multi-device collaboration 18 19OpenHarmony is a native distributed OS. Its application framework must be designed for easier component migration and collaboration across devices. The stage model achieves this design objective by providing features such as separation between ability and UI as well as integration of UI display and service capabilities. 20 21- Different window forms for various device types 22 23The stage model redefines the ability lifecycle. In terms of architecture, the component manager and window manager are decoupled. This facilitates adaptation between window forms and device types. 24 25## Basic Concepts 26 27The following figure shows the basic concepts in the stage model. 28 29![stageconcept](figures/stageconcept.png) 30 31- **HAP**: basic unit for building, distributing, and loading OpenHarmony applications. Each HAP corresponds to a module in the development state. In an application, **moduleName** uniquely identifies a module. 32- **Bundle**: an OpenHarmony application identified by **appid**. A bundle can contain multiple HAP files. Each application has a **bundleName**. However, **bundleName** must be used together with **appid** and other information to uniquely identify an application. 33- **AbilityStage**: runtime object of an HAP. It is created when the HAP is loaded to the process for the first time and is visible to developers in the runtime. 34- **Application**: runtime object of a bundle. It is invisible to developers in the runtime. 35- **Context**: base class that provides APIs in the runtime to obtain information such as the bundle name, module name, and path. The **Context** classes of the Ability and ExtensionAbility components inherit from this class. 36- **Ability**: provides lifecycle callbacks, holds the ability context, and supports cross-device component migration and multi-device collaboration. 37- **ExtensionAbility**: general name of scenario-based Extension abilities. The system defines multiple scenario-based **ExtensionAbility** classes, each of which has its own **ExtensionContext**. 38- **WindowStage**: local window manager. 39- **Window**: application window, which holds an ArkUI engine instance. 40- **ArkUI Page**: UI developed based on ArkUI. 41 42 43## Lifecycle 44 45The ability and ability stage are key objects in the application lifecycle. 46 47For details about the lifecycle differences between the stage model and FA model, see [Ability Framework Overview](ability-brief.md). This section focuses on the ability lifecycle transition and the scheduling relationships between the ability, ability stage, and window stage. 48 49![stageabilitylifecyclecallback](figures/stageabilitylifecyclecallback.png) 50 51To implement device adaptation and multi-window scalability, OpenHarmony decouples the component manager from the window manager. 52 53The ability lifecycle defined in the stage model includes only the creation, destruction, foreground, and background states. The gain focus and lose focus states that are closely related to UI are defined in the window stage. This implements weak coupling between the abilities and windows. On the service side, the window manager notifies the component manager of the foreground and background state changes, so the component manager only senses the foreground and background state changes but not the focus changes. 54 55There are two lifecycle states related to the window stage in **Ability**: **onWindowStageCreate** and **onWindowStageDestroy**. They are valid only for devices with the display capability. **onWindowStageCreate** is invoked when a window stage is created, where you can call **loadContent** to set pages to be loaded for the ability. **onWindowStageDestroy** is invoked when the window stage is destroyed, where you can release resources. 56 57 58## Ability Instances and Missions 59 60Abilities can be started in any of the following modes: 61 62* **Singleton**: For each type of ability, only one instance exists in the application process. **Ability1** in the figure below is started in singleton mode. 63* **Standard**: Each time **startAbility** is called, an instance of the specified ability type is created in the application process. **Ability2** in the figure below is started in standard mode. 64* **Specified**: Before creating an **Ability** instance, you can create a key for the instance. Each time **startAbility** is called, the system asks the application which ability instance (corresponding to a key) will be used. **Ability3** in the figure below is started in specified mode. 65 66Each **Ability** instance corresponds to a mission in **Recents**. 67 68The mission corresponding to an ability instance has a snapshot of the ability instance. After the ability instance is destroyed, the ability class information and snapshot are retained in the mission until the user deletes the information or the storage space reaches the upper limit. 69 70 ![AbilityComponentInstanceMission](figures/AbilityComponentInstanceMission.png) 71 72## ExtensionAbility Mechanism 73 74Different from the ability used for UI display, ExtensionAbility provides a restricted running environment. 75 76ExtensionAbility has the following features: 77 78- Its process runs independently from the main process but shares the same storage sandbox with the main process. There is no inter-process communication (IPC) between the ExtensionAbility process and the main process. 79 80- It has an independent context that provides scenario-specific APIs. 81 82- It is created by the system, rather than by applications. 83 84- The lifecycles of the ExtensionAbility component and process are managed by the system. 85 86The following figure uses the widget an example. **FormExtensionAbility** is the base class. You can inherit from this class to provide widget information. The lifecycle of the **FormExtensionAbility** instance and that of the ExtensionAbility process where the instance is located are managed by a system service named **FormManagerService**. 87 88![ExtensionAbility](figures/ExtensionAbility.png) 89 90## Process Model 91 92OpenHarmony forces strong control policies on application processes. No APIs are provided to configure multiple processes. All application processes are created and managed by the system. 93 94The processes of an application can be classified into three types: 95 96- Main process: runs the **UIAbility** component, UI, and service logic. 97 98- Extension process: runs classes derived from **ExtensionAbility** in the application. The lifecycle of this process is managed by a scenario-specific system service. 99 100- Render process: created for the WebView and used to load the WebView rendering library. 101 102 The following figure shows the process model of an application. 103 104 ![stageprocessmodel](figures/stageprocessmodel.png) 105 106 107 108## Application Package Structure 109 110For details about the project directory structure of the stage model, see [OpenHarmony Project Overview](https://developer.harmonyos.com/en/docs/documentation/doc-guides/ohos-project-overview-0000001218440650#section56487581904). 111 112For details about how to configure the application package structure of the stage model, see [Application Package Structure Configuration File](../quick-start/application-configuration-file-overview-stage.md). 113 114 115