From f8bb4df87615b8a525fd284123f8c65d8b2452b3 Mon Sep 17 00:00:00 2001 From: wangzhaoyong Date: Mon, 19 Sep 2022 20:38:44 +0800 Subject: [PATCH] add worker maxNum issue: https://gitee.com/openharmony/docs/issues/I5RWNX Signed-off-by: wangzhaoyong Change-Id: I2bf06f7c2dd8d5a9d4127037f47321c8ef5d7a01 --- .../reference/apis/js-apis-worker.md | 52 ++++++++++++++++--- 1 file changed, 44 insertions(+), 8 deletions(-) diff --git a/zh-cn/application-dev/reference/apis/js-apis-worker.md b/zh-cn/application-dev/reference/apis/js-apis-worker.md index d5d84f7f40..29edbc7173 100644 --- a/zh-cn/application-dev/reference/apis/js-apis-worker.md +++ b/zh-cn/application-dev/reference/apis/js-apis-worker.md @@ -29,7 +29,6 @@ Worker构造函数的选项信息,用于为Worker添加其他信息。 | 名称 | 参数类型 | 可读 | 可写 | 说明 | | ------ | --------- | ---- | ---- | ---------------------- | -| type | "classic" | 是 | 是 | 按照指定方式执行脚本。 | | name | string | 是 | 是 | Worker的名称。 | | shared | boolean | 是 | 是 | Worker是否可以被分享。 | @@ -691,23 +690,42 @@ parentPort.onerror = function(e){ } ``` +## 其他说明 + +### 内存模型 +Worker基于Actor并发模型实现。在Worker的交互流程中,JS主线程可以创建多个Worker子线程,各个Worker线程间相互隔离,并通过序列化传递对象,等到Worker线程完成计算任务,再把结果返回给主线程。 +Actor并发模型的交互原理:各个Actor并发地处理主线程任务,每个Actor内部都有一个消息队列及单线程执行模块,消息队列负责接收主线程及其他Actor的请求,单线程执行模块则负责串行地处理请求、向其他Actor发送请求以及创建新的Actor。由于Actor采用的是异步方式,各个Actor之间相互隔离没有数据竞争,因此Actor可以高并发运行。 + +### 注意事项 +- Worker存在数量限制,当前支持最多同时存在7个Worker。 +- 当Worker数量超出限制,会出现Error "Too many workers, the number of workers exceeds the maximum."。 +- 主动销毁Worker可以调用新创建Worker对象的terminate()或parentPort.close()方法。 +- Worker的创建和销毁耗费性能,建议管理已创建的Worker并重复使用。 + ## 完整示例 ### FA模型 ```js // main.js(同级目录为例) import worker from '@ohos.worker'; +// 主线程中创建Worker对象 const workerInstance = new worker.Worker("workers/worker.ts"); // 创建js和ts文件都可以 // const workerInstance = new worker.Worker("workers/worker.js"); +// 主线程向worker线程传递信息 workerInstance.postMessage("123"); + +// 主线程接收worker线程信息 workerInstance.onmessage = function(e) { + // data:worker线程发送的信息 let data = e.data; console.log("main.js onmessage"); - // 接收worker线程信息后执行terminate + + // 销毁Worker对象 workerInstance.terminate(); } -// 在调用terminate后,执行onexit + +// 在调用terminate后,执行回调onexit workerInstance.onexit = function() { console.log("main.js terminate"); } @@ -715,14 +733,21 @@ workerInstance.onexit = function() { ```js // worker.js import worker from '@ohos.worker'; + +// 创建worker线程中与主线程通信的对象 const parentPort = worker.parentPort +// worker线程接收主线程信息 parentPort.onmessage = function(e) { + // data:主线程发送的信息 let data = e.data; console.log("worker.js onmessage"); + + // worker线程向主线程发送信息 parentPort.postMessage("123") } +// worker线程发生error的回调 parentPort.onerror= function(e) { console.log("worker.js onerror"); } @@ -741,14 +766,22 @@ build-profile.json5 配置 : ```js // main.js(以不同目录为例) import worker from '@ohos.worker'; + +// 主线程中创建Worker对象 const workerInstance = new worker.Worker("entry/ets/pages/workers/worker.ts"); // 创建js和ts文件都可以 // const workerInstance = new worker.Worker("entry/ets/pages/workers/worker.js"); + +// 主线程向worker线程传递信息 workerInstance.postMessage("123"); + +// 主线程接收worker线程信息 workerInstance.onmessage = function(e) { + // data:worker线程发送的信息 let data = e.data; console.log("main.js onmessage"); - // 接收worker线程信息后执行terminate + + // 销毁Worker对象 workerInstance.terminate(); } // 在调用terminate后,执行onexit @@ -759,14 +792,21 @@ workerInstance.onexit = function() { ```js // worker.js import worker from '@ohos.worker'; + +// 创建worker线程中与主线程通信的对象 const parentPort = worker.parentPort +// worker线程接收主线程信息 parentPort.onmessage = function(e) { + // data:主线程发送的信息 let data = e.data; console.log("worker.js onmessage"); + + // worker线程向主线程发送信息 parentPort.postMessage("123") } +// worker线程发生error的回调 parentPort.onerror= function(e) { console.log("worker.js onerror"); } @@ -781,7 +821,3 @@ build-profile.json5 配置: } } ``` - -## 注意事项 -Worker存在数量限制,当前支持最多同时存在7个Worker。 -当Worker数量超出限制,会出现Error "Too many workers, the number of workers exceeds the maximum."。 \ No newline at end of file -- GitLab