Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Docs
提交
7f75659a
D
Docs
项目概览
OpenHarmony
/
Docs
接近 2 年 前同步成功
通知
159
Star
292
Fork
28
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
Docs
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
7f75659a
编写于
1月 04, 2023
作者:
朱
朱天怡
提交者:
Gitee
1月 04, 2023
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
延迟任务开发指南
Signed-off-by:
N
朱天怡
<
zhutianyi2@huawei.com
>
上级
f37fc613
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
80 addition
and
0 deletion
+80
-0
zh-cn/application-dev/application-models/workscheduler-extensionability.md
...-dev/application-models/workscheduler-extensionability.md
+80
-0
未找到文件。
zh-cn/application-dev/application-models/workscheduler-extensionability.md
0 → 100644
浏览文件 @
7f75659a
# WorkSchedulerExtensionAbility(延迟任务调度回调)
## 延迟任务概述
对于实时性要求不高的任务或持久性任务,可以使用延迟调度任务,该机制在满足应用设定条件的时候,会根据系统当前状态,如内存、功耗、温度等统一决策调度时间。
WorkSchedulerExtensionAbility提供了延迟任务回调能力,在延迟任务开始和结束时,系统会通过接口回调应用,开发者可在回调接口里面处理自己的任务逻辑。
## 运作机制
延迟任务调度运作机制如图1所示。
**图1**
延迟任务调度运作机制

应用通过
[
延迟任务API
](
../reference/apis/js-apis-resourceschedule-workScheduler.md
)
注册、删除、查询任务。
应用服务侧进行条件检测和判断,若满足条件,则回调WorkSchedulerExtensionAbility拉起应用,执行onWorkStart、onWorkStop回调接口。
## 接口说明
WorkSchedulerExtensionAbility类拥有如下API接口,具体的API介绍详见
[
接口文档
](
../reference/apis/js-apis-app-form-formExtensionAbility.md
)
。
| 接口名 | 描述 |
| -------- | -------- |
| onWorkStart(work: workScheduler.WorkInfo): void | 延迟任务调度开始回调。 |
| onWorkStop(work: workScheduler.WorkInfo): void | 延迟任务调度结束回调。 |
## 开发步骤
在DevEco Studio工程中手动新建一个WorkSchedulerExtensionAbility工程,具体步骤如下。
1.
在工程Module对应的ets目录下,右键选择“New
>
Directory”,新建一个目录并命名为WorkSchedulerExtension。
2.
在WorkSchedulerExtension目录,右键选择“New
>
TypeScript File”,新建一个TypeScript文件并命名为WorkSchedulerExtension.ts。
3.
打开WorkSchedulerExtension.ts文件,导入模块。
```
ts
import
WorkSchedulerExtensionAbility
from
'
@ohos.WorkSchedulerExtensionAbility
'
```
4.
在WorkSchedulerExtension.ts中,实现WorkSchedulerExtension生命周期接口。
```
ts
export
default
class
MyWorkSchedulerExtensionAbility
extends
WorkSchedulerExtensionAbility
{
onWorkStart
(
workInfo
)
{
console
.
log
(
'
MyWorkSchedulerExtensionAbility onWorkStart
'
+
JSON
.
stringify
(
workInfo
));
}
onWorkStop
(
workInfo
)
{
console
.
log
(
'
MyWorkSchedulerExtensionAbility onWorkStop
'
+
JSON
.
stringify
(
workInfo
));
}
}
```
5.
在工程Module对应的
[
module.json5配置文件
](
../quick-start/module-configuration-file.md
)
中注册WorkSchedulerExtensionAbility,type标签需要设置为“workScheduler”,srcEntrance标签表示当前ExtensionAbility组件所对应的代码路径。
```
json
{
"module"
:
{
//
...
"extensionAbilities"
:
[
{
"name"
:
"ServiceExtAbility"
,
"description"
:
"workScheduler"
,
"type"
:
"workScheduler"
,
"srcEntrance"
:
"./ets/WorkSchedulerExtension/WorkSchedulerExtension.ts"
}
]
}
}
```
6.
在工程中实现延迟任务注册、删除等功能,延迟任务接口说明见
[
延迟任务API
](
../reference/apis/js-apis-resourceschedule-workScheduler.md
)
。
## 相关实例
针对WorkSchedulerExtensionAbility开发,有以下相关示例可供参考:
[
WorkSchedulerExtensionAbility的创建与使用(ArkTS)(API9)(Full SDK)
](
https://gitee.com/openharmony/applications_app_samples/tree/master/ability/WorkSchedExtAbility
)
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录