Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Docs
提交
307e8fe4
D
Docs
项目概览
OpenHarmony
/
Docs
1 年多 前同步成功
通知
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看板
未验证
提交
307e8fe4
编写于
1月 05, 2023
作者:
O
openharmony_ci
提交者:
Gitee
1月 05, 2023
浏览文件
操作
浏览文件
下载
差异文件
!13225 add md for taskpool(weekly)
Merge pull request !13225 from wangzhaoyong/weekly_20221227
上级
1d092815
c0f859c9
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
248 addition
and
0 deletion
+248
-0
zh-cn/application-dev/reference/apis/Readme-CN.md
zh-cn/application-dev/reference/apis/Readme-CN.md
+1
-0
zh-cn/application-dev/reference/apis/js-apis-taskpool.md
zh-cn/application-dev/reference/apis/js-apis-taskpool.md
+193
-0
zh-cn/application-dev/reference/errorcodes/errorcode-utils.md
...n/application-dev/reference/errorcodes/errorcode-utils.md
+54
-0
未找到文件。
zh-cn/application-dev/reference/apis/Readme-CN.md
浏览文件 @
307e8fe4
...
...
@@ -343,6 +343,7 @@
-
[
@ohos.buffer (Buffer)
](
js-apis-buffer.md
)
-
[
@ohos.convertxml (xml转换JavaScript)
](
js-apis-convertxml.md
)
-
[
@ohos.process (获取进程相关的信息)
](
js-apis-process.md
)
-
[
@ohos.taskpool (启动任务池)
](
js-apis-taskpool.md
)
-
[
@ohos.uri (URI字符串解析)
](
js-apis-uri.md
)
-
[
@ohos.url (URL字符串解析)
](
js-apis-url.md
)
-
[
@ohos.util (util工具函数)
](
js-apis-util.md
)
...
...
zh-cn/application-dev/reference/apis/js-apis-taskpool.md
0 → 100644
浏览文件 @
307e8fe4
# @ohos.taskpool(使用任务池)
taskpool作用是为应用程序提供一个多线程的运行环境,可以降低整体资源的消耗、提高系统的整体性能,且用户无需关心线程实例的生命周期。
> **说明:**<br/>
> 本模块首批接口从API version 9 开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。
## 导入模块
```
js
import
taskpool
from
'
@ohos.taskpool
'
;
```
## Priority
表示所创建任务(Task)的优先级。(暂未支持)
**系统能力:**
SystemCapability.Utils.Lang
| 名称 | 值 | 说明 |
| -------- | -------- | -------- |
| HIGH | 0 | 任务为高优先级。 |
| MEDIUM | 1 | 任务为中优先级。 |
| LOW | 2 | 任务为低优先级。 |
## Task
表示任务。使用以下方法前,需要先构造Task。
### constructor
constructor(func: Function, ...args: unknown[])
Task的构造函数。
**系统能力:**
SystemCapability.Utils.Lang
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | --------- | ---- | ------------------------ |
| func | Function | 是 | 任务执行需要传入函数。 |
| args | unknown[] | 否 | 任务执行传入函数的参数。 |
**错误码:**
以下错误码的详细介绍请参见
[
语言基础类库错误码
](
../errorcodes/errorcode-utils.md
)
。
| 错误码ID | 错误信息 |
| -------- | --------------------------------------- |
| 10200014 | The function is not mark as concurrent. |
**示例:**
```
js
function
func
(
args
)
{
"
use concurrent
"
console
.
log
(
"
func:
"
+
args
);
return
args
;
}
let
task
=
new
taskpool
.
Task
(
func
,
"
this is my first Task
"
);
```
### 属性
**系统能力:**
SystemCapability.Utils.Lang
| 名称 | 类型 | 可读 | 可写 | 说明 |
| --------- | --------- | ---- | ---- | ---------------------------- |
| function | Function | 是 | 是 | 创建任务时需要传入的函数。 |
| arguments | unknown[] | 是 | 是 | 创建任务传入函数所需的参数。 |
## taskpool.execute
execute(func: Function, ...args: unknown[]): Promise
\<
unknown>
任务池执行任务,需要传入待执行的函数和函数所需的参数,此执行模式不可取消任务。
**系统能力:**
SystemCapability.Utils.Lang
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | --------- | ---- | ---------------------------- |
| func | Function | 是 | 执行的逻辑需要传入函数。 |
| args | unknown[] | 否 | 执行逻辑的函数所需要的参数。 |
**返回值:**
| 类型 | 说明 |
| ----------------- | ------------------------------------ |
| Promise
\<
unknown> | execute是异步方法,返回Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见
[
语言基础类库错误码
](
../errorcodes/errorcode-utils.md
)
。
| 错误码ID | 错误信息 |
| -------- | ----------------------------------------- |
| 10200003 | Worker initialization failure. |
| 10200006 | Serializing an uncaught exception failed. |
| 10200014 | The function is not mark as concurrent. |
**示例:**
```
js
function
func
(
args
)
{
"
use concurrent
"
console
.
log
(
"
func:
"
+
args
);
return
args
;
}
let
value
=
taskpool
.
execute
(
func
,
100
);
```
## taskpool.execute
execute(task: Task, priority?: Priority): Promise
\<
unknown>
任务池执行任务,需要传入已创建的任务,此执行模式可取消任务。
**系统能力:**
SystemCapability.Utils.Lang
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | --------------------- | ---- | ------------------------------------ |
| task |
[
Task
](
#task
)
| 是 | 需要在任务池中执行的任务。 |
| priority |
[
Priority
](
#priority
)
| 否 | 等待执行的任务的优先级(暂未支持)。 |
**返回值:**
| 类型 | 说明 |
| ---------------- | ------------------------------ |
| Promise
\<
unknown> | execute是异步方法,返回Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见
[
语言基础类库错误码
](
../errorcodes/errorcode-utils.md
)
。
| 错误码ID | 错误信息 |
| -------- | ----------------------------------------- |
| 10200003 | Worker initialization failure. |
| 10200006 | Serializing an uncaught exception failed. |
| 10200014 | The function is not mark as concurrent. |
**示例:**
```
js
function
func
(
args
)
{
"
use concurrent
"
console
.
log
(
"
func:
"
+
args
);
return
args
;
}
let
task
=
new
taskpool
.
Task
(
func
,
"
this is my first Task
"
);
let
value
=
taskpool
.
execute
(
task
);
```
## taskpool.cancel
cancel(task: Task): void
取消任务池中的任务。
**系统能力:**
SystemCapability.Utils.Lang
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------------- | ---- | -------------------- |
| task |
[
Task
](
#task
)
| 是 | 需要取消执行的任务。 |
**错误码:**
以下错误码的详细介绍请参见
[
语言基础类库错误码
](
../errorcodes/errorcode-utils.md
)
。
| 错误码ID | 错误信息 |
| -------- | ------------------------- |
| 10200015 | If the task is not exist. |
| 10200016 | If the task is running. |
**示例:**
```
js
function
func
(
args
)
{
"
use concurrent
"
console
.
log
(
"
func:
"
+
args
);
return
args
;
}
let
task
=
new
taskpool
.
Task
(
func
,
"
this is first Task
"
);
let
value
=
taskpool
.
execute
(
task
);
taskpool
.
cancel
(
task
);
```
\ No newline at end of file
zh-cn/application-dev/reference/errorcodes/errorcode-utils.md
浏览文件 @
307e8fe4
...
...
@@ -219,3 +219,57 @@ Buffer的属性${propertyName}只读,不能进行设置。
**处理步骤**
不要对Buffer只读属性进行相关设置。
## 10200014 非Concurrent函数错误
**错误信息**
The function is not mark as concurrent.
**错误描述**
Function未被标记为concurrent。
**可能原因**
任务池执行的任务所需的函数未添加@Concurrent。
**处理步骤**
检查任务池执行的任务所需的函数,并补上@Concurrent装饰器。
## 10200015 取消不存在的任务错误
**错误信息**
The task is not exist when cancel it.
**错误描述**
取消一个不存在的任务。
**可能原因**
取消任务时,该任务并不存在于任务池中。
**处理步骤**
取消任务前,确保任务已被taskpool.execute调用进入任务池。
## 10200016 取消已执行的任务错误
**错误信息**
The task is running when cancel it.
**错误描述**
取消已经执行的任务。
**可能原因**
取消任务时,该任务已经处于执行状态。
**处理步骤**
取消任务前,确保任务已被执行完毕。
\ No newline at end of file
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录