
HarmonyOS API:@ohos.worker (启动一个Worker)
版本:v3.1 Beta
@ohos.worker (启动一个Worker)
MessageEvents9+
消息类,持有Worker线程间传递的数据。
系统能力: SystemCapability.Utils.Lang
名称 | 类型 | 可读 | 可写 | 说明 |
data | any | 是 | 否 | 线程间传递的数据。 |
Worker(deprecated)
使用以下方法前,均需先构造Worker实例,Worker类继承EventTarget。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用ThreadWorker9+替代。
constructor(deprecated)
constructor(scriptURL: string, options?: WorkerOptions)
Worker构造函数。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用ThreadWorker.constructor9+替代。
系统能力: SystemCapability.Utils.Lang
参数:
参数名 | 类型 | 必填 | 说明 |
scriptURL | string | 是 | Worker执行脚本的路径。 在FA和Stage模型下,DevEco Studio新建Worker工程路径分别存在以下两种情况: (a) worker脚本所在目录与pages目录同级。 (b) worker脚本所在目录与pages目录不同级。 |
options | 否 | Worker构造的选项。 |
返回值:
类型 | 说明 |
Worker | 执行Worker构造函数生成的Worker对象,失败则返回undefined。 |
示例:
同时,需在工程的模块级build-profile.json5文件的buildOption属性中添加配置信息,主要分为下面两种情况:
(1) 目录同级
FA模型:
Stage模型:
(2) 目录不同级
FA模型:
Stage模型:
postMessage(deprecated)
postMessage(message: Object, transfer: ArrayBuffer[]): void;
向Worker线程发送数据,数据类型必须是序列化所支持的类型。序列化支持类型见其他说明。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用ThreadWorker.postMessage9+替代。
系统能力: SystemCapability.Utils.Lang
参数:
参数名 | 类型 | 必填 | 说明 |
message | Object | 是 | 发送至Worker的数据。 |
transfer | ArrayBuffer[] | 是 | 可转移对象是 ArrayBuffer 的实例对象。 |
示例:
postMessage(deprecated)
postMessage(message: Object, options?: PostMessageOptions): void
向Worker线程发送数据,数据类型必须是序列化所支持的类型。序列化支持类型见其他说明。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用ThreadWorker.postMessage9+替代。
系统能力: SystemCapability.Utils.Lang
参数:
参数名 | 类型 | 必填 | 说明 |
message | Object | 是 | 发送至Worker的数据。 |
options | 否 | 可转移对象是 ArrayBuffer 的实例对象。transferList数组中不可传入null。 |
示例:
on(deprecated)
on(type: string, listener: EventListener): void
向Worker添加一个事件监听,该接口与addEventListener(deprecated)接口功能一致。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用ThreadWorker.on9+替代。
系统能力: SystemCapability.Utils.Lang
参数:
参数名 | 类型 | 必填 | 说明 |
type | string | 是 | 监听的事件类型。 |
listener | 是 | 回调事件。 |
示例:
once(deprecated)
once(type: string, listener: EventListener): void
向Worker添加一个事件监听,事件监听只执行一次便自动删除。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用ThreadWorker.once9+替代。
系统能力: SystemCapability.Utils.Lang
参数:
参数名 | 类型 | 必填 | 说明 |
type | string | 是 | 监听的事件类型。 |
listener | 是 | 回调事件。 |
示例:
off(deprecated)
off(type: string, listener?: EventListener): void
删除类型为type的事件监听,该接口与removeEventListener(deprecated)接口功能一致。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用ThreadWorker.off9+替代。
系统能力: SystemCapability.Utils.Lang
参数:
参数名 | 类型 | 必填 | 说明 |
type | string | 是 | 需要删除的事件类型。 |
listener | 否 | 删除的回调事件。 |
示例:
terminate(deprecated)
terminate(): void
销毁Worker线程,终止Worker接收消息。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用ThreadWorker.terminate9+替代。
系统能力: SystemCapability.Utils.Lang
示例:
onexit(deprecated)
onexit?: (code: number) => void
Worker对象的onexit属性表示Worker销毁时被调用的事件处理程序,处理程序在宿主线程中执行。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用ThreadWorker.onexit9+替代。
系统能力: SystemCapability.Utils.Lang
参数:
参数名 | 类型 | 必填 | 说明 |
code | number | 是 | Worker退出的code。 |
示例:
onerror(deprecated)
onerror?: (err: ErrorEvent) => void
Worker对象的onerror属性表示Worker在执行过程中发生异常被调用的事件处理程序,处理程序在宿主线程中执行。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用ThreadWorker.onerror9+替代。
系统能力: SystemCapability.Utils.Lang
参数:
参数名 | 类型 | 必填 | 说明 |
err | 是 | 异常数据。 |
示例:
onmessage(deprecated)
onmessage?: (event: MessageEvent) => void
Worker对象的onmessage属性表示宿主线程接收到来自其创建的Worker通过parentPort.postMessage接口发送的消息时被调用的事件处理程序,处理程序在宿主线程中执行。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用ThreadWorker.onmessage9+替代。
系统能力: SystemCapability.Utils.Lang
参数:
参数名 | 类型 | 必填 | 说明 |
event | 是 | 收到的Worker消息数据。 |
示例:
onmessageerror(deprecated)
onmessageerror?: (event: MessageEvent) => void
Worker对象的onmessageerror属性表示当Worker对象接收到一条无法被序列化的消息时被调用的事件处理程序,处理程序在宿主线程中执行。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用ThreadWorker.onmessageerror9+替代。
系统能力: SystemCapability.Utils.Lang
参数:
参数名 | 类型 | 必填 | 说明 |
event | 是 | 异常数据。 |
示例:
EventTarget(deprecated)
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用WorkerEventTarget9+替代。
addEventListener(deprecated)
addEventListener(type: string, listener: EventListener): void
向Worker添加一个事件监听,该接口与on(deprecated)接口功能一致。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用addEventListener9+替代。
系统能力: SystemCapability.Utils.Lang
参数:
参数名 | 类型 | 必填 | 说明 |
type | string | 是 | 监听的事件类型。 |
listener | 是 | 回调的事件。 |
示例:
removeEventListener(deprecated)
removeEventListener(type: string, callback?: EventListener): void
删除Worker的事件监听,该接口与off(deprecated)接口功能一致。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用removeEventListener9+替代。
系统能力: SystemCapability.Utils.Lang
参数:
参数名 | 类型 | 必填 | 说明 |
type | string | 是 | 需要删除的监听事件类型。 |
callback | 否 | 删除的回调事件。 |
示例:
dispatchEvent(deprecated)
dispatchEvent(event: Event): boolean
分发定义在Worker的事件。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用dispatchEvent9+替代。
系统能力: SystemCapability.Utils.Lang
参数:
参数名 | 类型 | 必填 | 说明 |
event | Event | 是 | 需要分发的事件。 |
返回值:
类型 | 说明 |
boolean | 分发的结果,false表示分发失败。 |
示例:
removeAllListener(deprecated)
removeAllListener(): void
删除Worker所有的事件监听。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用removeAllListener9+替代。
系统能力: SystemCapability.Utils.Lang
示例:
DedicatedWorkerGlobalScope(deprecated)
Worker线程用于与宿主线程通信的类,通过postMessage接口发送消息给宿主线程、close接口销毁Worker线程。DedicatedWorkerGlobalScope类继承WorkerGlobalScope。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用ThreadWorkerGlobalScope9+替代。
postMessage9+
postMessage(messageObject: Object, transfer: ArrayBuffer[]): void;
Worker线程向宿主线程发送消息。
系统能力: SystemCapability.Utils.Lang
参数:
参数名 | 类型 | 必填 | 说明 |
message | Object | 是 | 发送至宿主线程的数据。 |
transfer | ArrayBuffer[] | 是 | 可传输对象是ArrayBuffer的实例对象,数组不可传入null。 |
示例:
postMessage(deprecated)
postMessage(messageObject: Object, options?: PostMessageOptions): void
Worker线程向宿主线程发送消息。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用ThreadWorkerGlobalScope9+.postMessage9+替代。
系统能力: SystemCapability.Utils.Lang
参数:
参数名 | 类型 | 必填 | 说明 |
message | Object | 是 | 发送至宿主线程的数据。 |
options | 否 | 可转移对象是ArrayBuffer的实例对象。transferList数组中不可传入null。 |
示例:
close(deprecated)
close(): void
销毁Worker线程,终止Worker接收消息。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用ThreadWorkerGlobalScope9+.close9+替代。
系统能力: SystemCapability.Utils.Lang
示例:
onmessage(deprecated)
onmessage?: (this: DedicatedWorkerGlobalScope, ev: MessageEvent) => void
DedicatedWorkerGlobalScope的onmessage属性表示Worker线程收到来自其宿主线程通过postMessage接口发送的消息时被调用的事件处理程序,处理程序在Worker线程中执行。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用ThreadWorkerGlobalScope9+.onmessage9+替代。
系统能力: SystemCapability.Utils.Lang
参数:
参数名 | 类型 | 必填 | 说明 |
this | 是 | 指向调用者对象。 | |
ev | 是 | 收到宿主线程发送的数据。 |
示例:
onmessageerror(deprecated)
onmessageerror?: (this: DedicatedWorkerGlobalScope, ev: MessageEvent) => void
DedicatedWorkerGlobalScope的onmessageerror属性表示当Worker对象接收到一条无法被反序列化的消息时被调用的事件处理程序,处理程序在Worker线程中执行。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用ThreadWorkerGlobalScope9+.onmessageerror9+替代。
系统能力: SystemCapability.Utils.Lang
参数:
参数名 | 类型 | 必填 | 说明 |
this | 是 | 指向调用者对象。 | |
ev | 是 | 异常数据。 |
示例:
PostMessageOptions
明确数据传递过程中需要转移所有权对象的类,传递所有权的对象必须是ArrayBuffer。
系统能力: SystemCapability.Utils.Lang
名称 | 类型 | 可读 | 可写 | 说明 |
transfer | Object[] | 是 | 是 | ArrayBuffer数组,用于传递所有权。 |
Event
事件类。
系统能力: SystemCapability.Utils.Lang
名称 | 类型 | 可读 | 可写 | 说明 |
type | string | 是 | 否 | 指定事件的类型。 |
timeStamp | number | 是 | 否 | 事件创建时的时间戳(精度为毫秒),暂未支持。 |
EventListener(deprecated)
(evt: Event): void | Promise<void>
事件监听类。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用WorkerEventListener9+替代。
系统能力: SystemCapability.Utils.Lang
参数:
参数名 | 类型 | 必填 | 说明 |
evt | Event | 是 | 回调的事件类。 |
返回值:
类型 | 说明 |
void | Promise<void> | 无返回值或者以Promise形式返回。 |
示例:
ErrorEvent
错误事件类,用于表示Worker执行过程中出现异常的详细信息,ErrorEvent类继承Event。
系统能力: SystemCapability.Utils.Lang
名称 | 类型 | 可读 | 可写 | 说明 |
message | string | 是 | 否 | 异常发生的错误信息。 |
filename | string | 是 | 否 | 出现异常所在的文件。 |
lineno | number | 是 | 否 | 异常所在的行数。 |
colno | number | 是 | 否 | 异常所在的列数。 |
error | Object | 是 | 否 | 异常类型。 |
MessageEvent<T>
消息类,持有Worker线程间传递的数据。
系统能力: SystemCapability.Utils.Lang
名称 | 类型 | 可读 | 可写 | 说明 |
data | T | 是 | 否 | 线程间传递的数据。 |
WorkerGlobalScope(deprecated)
Worker线程自身的运行环境,WorkerGlobalScope类继承EventTarget。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用GlobalScope9+替代。
属性
系统能力: SystemCapability.Utils.Lang
名称 | 类型 | 可读 | 可写 | 说明 |
name | string | 是 | 否 | Worker的名字,new Worker时指定。 |
self | WorkerGlobalScope & typeof globalThis | 是 | 否 | WorkerGlobalScope本身。 |
onerror(deprecated)
onerror?: (ev: ErrorEvent) => void
WorkerGlobalScope的onerror属性表示Worker在执行过程中发生异常被调用的事件处理程序,处理程序在Worker线程中执行。
说明
从API version 7 开始支持,从API version 9 开始废弃,建议使用GlobalScope9+.onerror替代。
系统能力: SystemCapability.Utils.Lang
参数:
参数名 | 类型 | 必填 | 说明 |
ev | 是 | 异常数据。 |
示例:
其他说明
序列化支持类型
Type | 备注 | 是否支持 |
All Primitive Type | 不包括symbol | 是 |
Date |
| 是 |
String |
| 是 |
RegExp |
| 是 |
Array |
| 是 |
Map |
| 是 |
Set |
| 是 |
Object | 只支持Plain Object,不支持带function的 | 是 |
ArrayBuffer | 提供transfer能力 | 是 |
TypedArray |
| 是 |
特例:传递通过自定义class创建出来的object时,不会发生序列化错误,但是自定义class的属性(如Function)无法通过序列化传递。
说明
以API version 9的FA工程为例。
内存模型
Worker基于Actor并发模型实现。在Worker的交互流程中,JS主线程可以创建多个Worker子线程,各个Worker线程间相互隔离,并通过序列化传递对象,等到Worker线程完成计算任务,再把结果返回给主线程。
Actor并发模型的交互原理:各个Actor并发地处理主线程任务,每个Actor内部都有一个消息队列及单线程执行模块,消息队列负责接收主线程及其他Actor的请求,单线程执行模块则负责串行地处理请求、向其他Actor发送请求以及创建新的Actor。由于Actor采用的是异步方式,各个Actor之间相互隔离没有数据竞争,因此Actor可以高并发运行。
注意事项
- Worker存在数量限制,当前支持最多同时存在7个Worker。
- 在API version 8及之前的版本,当Worker数量超出限制时,会抛出错误Error "Too many workers, the number of workers exceeds the maximum."。
- 从API version 9开始,当Worker数量超出限制时,会抛出错误BusinessError "Worker initialization failure, the number of workers exceeds the maximum"。
- 主动销毁Worker可以调用新创建Worker对象的terminate()或parentPort.close()方法。
- 自API version 9版本开始,若Worker处于已经销毁或正在销毁等非运行状态时,调用其功能接口,会抛出相应的BusinessError。
- Worker的创建和销毁耗费性能,建议管理已创建的Worker并重复使用。
- 创建Worker工程时,new worker.Worker构造函数和new worker.ThreadWorker构造函数不能同时使用,否则将导致工程中Worker的功能异常。自API version 9版本开始,建议使用new worker.ThreadWorker构造函数,在API version 8及之前的版本,建议使用new worker.Worker构造函数。
- 创建Worker工程时,在Worker线程的文件中(比如本文中worker.ts)不能导入任何有关构建UI的方法(比如ets文件等),否则会导致Worker的功能失效。排查方式:解压生成的Hap包,在创建Worker线程的文件目录中找到"worker.js",全局搜索"View"关键字。如果存在该关键字,说明在worker.js中打包进去了构建UI的方法,会导致Worker的功能失效,建议在创建Worker线程的文件中修改 "import “xxx” from src"中src的目录层级。
完整示例
说明
以API version 9的工程为例。
API version 8及之前的版本仅支持FA模型,如需使用,注意更换构造Worker的接口和创建worker线程中与主线程通信的对象的两个方法。
FA模型
build-profile.json5 配置 :
Stage模型
build-profile.json5 配置:
