UIAbility生命周期
UIAbility生命周期
什么是UIAbility? UIAbility组件是一种包含UI的应用组件,主要用于和用户交互 。它是HarmonyOS中用于系统调度的基本单元,为应用提供绘制界面的窗口。
其他官方专业数据就不赘述了,简单将就是手机应用里的一个UI窗口。这个类比Android里的Activity,都是UI的应用组件。
官方入口
基础理论
先看看官方的图片介绍

Android中Activity的生命周期

UIAbility的生命周期包括Create、Foreground、Background、Destroy四个状态。UIAbility是类比Android的Activity的,但是UIAbility的生命周期进行了简化,也更容易理解,所以你可以说Harmony借鉴了Android的一些思想,但是绝对不是套壳!
在Foreground和Backgroud之间还有两个中间状态:WindowStageCreate和WindowStageDestroy,按着官方说法者两个状态不属于Ability的生命周期里的状态。这个我也没明白这么设计,我问DevEcoStudio里的CodeGenie,它是这么回答我的:
您提到的WindowStageCreate确实与UIAbility的生命周期相关,但它不是UIAbility的直接生命周期状态之一。在HarmonyOS中,UIAbility的生命周期包括Create、Foreground、Background和Destroy四个状态 。
WindowStageCreate状态发生在UIAbility的Create状态之后,但在Foreground状态之前 。这个状态是专门用于表示UIAbility实例在完全创建后,但在进入前台之前,系统为其创建一个WindowStage的过程 。在这个阶段,可以通过onWindowStageCreate()回调方法来设置UI加载和配置WindowStage的事件订阅。
因此,虽然WindowStageCreate不是UIAbility的四大基本生命周期状态之一,但它是一个重要的中间状态,对于UI的初始化和配置非常关键。希望这能帮助您更好地理解HarmonyOS中UIAbility的生命周期。如果您有其他关于HarmonyOS开发的问题,欢迎继续提问!
准确说WindowStageCreate和WindowStageDestroy是UIAbility的两个中间状态。
实战说明
我们使用DevEcoStudio创建一个新工程,默认会生成一个EntryAbility这个是应用的入口界面。
export default class EntryAbility extends UIAbility {
onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onCreate');
}
onDestroy(): void {
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onDestroy');
}
onWindowStageCreate(windowStage: window.WindowStage): void {
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onWindowStageCreate');
windowStage.loadContent('pages/Index', (err) => {
if (err.code) {
hilog.error(0x0000, 'testTag', 'Failed to load the content. Cause: %{public}s', JSON.stringify(err) ?? '');
return;
}
hilog.info(0x0000, 'testTag', 'Succeeded in loading the content.');
});
}
onWindowStageDestroy(): void {
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onWindowStageDestroy');
}
onForeground(): void {
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onForeground');
}
onBackground(): void {
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onBackground');
}
}
默认程序会为我们在各个生命周期打印日志,我启动应用后做了如下操作,我们可以看下生命周期情况。
- 启动应用
02-20 12:55:45.456 4852-4852 A00000/testTag pid-4852 I Ability onCreate
02-20 12:55:45.467 4852-4852 A00000/testTag pid-4852 I Ability onWindowStageCreate
02-20 12:55:45.479 4852-4852 A00000/testTag pid-4852 I Ability onForeground
UIAbility运行状态是onCreate->onWindowStageCreate->onForeground
- 推到桌面
02-20 15:06:49.565 3574-3574 A00000/testTag com.byrai...mple_001 I Ability onBackground
在上面基础上进入了onBackground状态
- 再次图标打开应用
02-20 15:08:25.821 3574-3574 A00000/testTag com.byrai...mple_001 I Ability onForeground
UIAbility有进入前台状态onForeground
- 点击任务切换按钮(全面屏中底部向上滑动)
切换多任务状态下,应用没有打印日志,也就说明应用生命周期没有任务变化,这个过程UIAbility可以理解为还是用户可见的前台运行状态
- 任务切换状态下,向上滑动结束应用
02-20 15:11:51.971 3574-3574 A00000/testTag com.byrai...mple_001 I Ability onBackground
02-20 15:11:52.028 3574-3574 A00000/testTag com.byrai...mple_001 I Ability onWindowStageDestroy
02-20 15:11:52.028 3574-3574 A00000/testTag com.byrai...mple_001 I Ability onDestroy
UIAbility的状态变化是:onBackground->onWindowStageDestroy->onDestroy,页面从前台进入后台然后销毁
- 打开页面后按返回键
02-20 15:13:22.757 5794-5794 A00000/testTag pid-5794 I Ability onCreate
02-20 15:13:22.797 5794-5794 A00000/testTag pid-5794 I Ability onWindowStageCreate
02-20 15:13:22.824 5794-5794 A00000/testTag pid-5794 I Ability onForeground
02-20 15:13:22.890 5794-5794 A00000/testTag pid-5794 I Succeeded in loading the content.
02-20 15:13:28.148 5794-5794 A00000/testTag com.byrai...mple_001 I Ability onBackground
通过日志可以看到,当应用启动后仅仅按返回键,页面实际是进入后台运行并没有关闭结束进程。只有当多任务下结束应用或者系统资源不足回收情况下页面才会销毁
上面的几种情况基本涵盖了我们常用的操作。通过这几个操作我们可以更加深入了解UIAbility生命周期中各种状态变化。

浙公网安备 33010602011771号