提交 f8bb4df8 编写于 作者: W wangzhaoyong

add worker maxNum

issue: https://gitee.com/openharmony/docs/issues/I5RWNXSigned-off-by: Nwangzhaoyong <wangzhaoyong@huawei.com>
Change-Id: I2bf06f7c2dd8d5a9d4127037f47321c8ef5d7a01
上级 2af4e6d3
...@@ -29,7 +29,6 @@ Worker构造函数的选项信息,用于为Worker添加其他信息。 ...@@ -29,7 +29,6 @@ Worker构造函数的选项信息,用于为Worker添加其他信息。
| 名称 | 参数类型 | 可读 | 可写 | 说明 | | 名称 | 参数类型 | 可读 | 可写 | 说明 |
| ------ | --------- | ---- | ---- | ---------------------- | | ------ | --------- | ---- | ---- | ---------------------- |
| type | "classic" | 是 | 是 | 按照指定方式执行脚本。 |
| name | string | 是 | 是 | Worker的名称。 | | name | string | 是 | 是 | Worker的名称。 |
| shared | boolean | 是 | 是 | Worker是否可以被分享。 | | shared | boolean | 是 | 是 | Worker是否可以被分享。 |
...@@ -691,23 +690,42 @@ parentPort.onerror = function(e){ ...@@ -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模型 ### FA模型
```js ```js
// main.js(同级目录为例) // main.js(同级目录为例)
import worker from '@ohos.worker'; import worker from '@ohos.worker';
// 主线程中创建Worker对象
const workerInstance = new worker.Worker("workers/worker.ts"); const workerInstance = new worker.Worker("workers/worker.ts");
// 创建js和ts文件都可以 // 创建js和ts文件都可以
// const workerInstance = new worker.Worker("workers/worker.js"); // const workerInstance = new worker.Worker("workers/worker.js");
// 主线程向worker线程传递信息
workerInstance.postMessage("123"); workerInstance.postMessage("123");
// 主线程接收worker线程信息
workerInstance.onmessage = function(e) { workerInstance.onmessage = function(e) {
// data:worker线程发送的信息
let data = e.data; let data = e.data;
console.log("main.js onmessage"); console.log("main.js onmessage");
// 接收worker线程信息后执行terminate
// 销毁Worker对象
workerInstance.terminate(); workerInstance.terminate();
} }
// 在调用terminate后,执行onexit
// 在调用terminate后,执行回调onexit
workerInstance.onexit = function() { workerInstance.onexit = function() {
console.log("main.js terminate"); console.log("main.js terminate");
} }
...@@ -715,14 +733,21 @@ workerInstance.onexit = function() { ...@@ -715,14 +733,21 @@ workerInstance.onexit = function() {
```js ```js
// worker.js // worker.js
import worker from '@ohos.worker'; import worker from '@ohos.worker';
// 创建worker线程中与主线程通信的对象
const parentPort = worker.parentPort const parentPort = worker.parentPort
// worker线程接收主线程信息
parentPort.onmessage = function(e) { parentPort.onmessage = function(e) {
// data:主线程发送的信息
let data = e.data; let data = e.data;
console.log("worker.js onmessage"); console.log("worker.js onmessage");
// worker线程向主线程发送信息
parentPort.postMessage("123") parentPort.postMessage("123")
} }
// worker线程发生error的回调
parentPort.onerror= function(e) { parentPort.onerror= function(e) {
console.log("worker.js onerror"); console.log("worker.js onerror");
} }
...@@ -741,14 +766,22 @@ build-profile.json5 配置 : ...@@ -741,14 +766,22 @@ build-profile.json5 配置 :
```js ```js
// main.js(以不同目录为例) // main.js(以不同目录为例)
import worker from '@ohos.worker'; import worker from '@ohos.worker';
// 主线程中创建Worker对象
const workerInstance = new worker.Worker("entry/ets/pages/workers/worker.ts"); const workerInstance = new worker.Worker("entry/ets/pages/workers/worker.ts");
// 创建js和ts文件都可以 // 创建js和ts文件都可以
// const workerInstance = new worker.Worker("entry/ets/pages/workers/worker.js"); // const workerInstance = new worker.Worker("entry/ets/pages/workers/worker.js");
// 主线程向worker线程传递信息
workerInstance.postMessage("123"); workerInstance.postMessage("123");
// 主线程接收worker线程信息
workerInstance.onmessage = function(e) { workerInstance.onmessage = function(e) {
// data:worker线程发送的信息
let data = e.data; let data = e.data;
console.log("main.js onmessage"); console.log("main.js onmessage");
// 接收worker线程信息后执行terminate
// 销毁Worker对象
workerInstance.terminate(); workerInstance.terminate();
} }
// 在调用terminate后,执行onexit // 在调用terminate后,执行onexit
...@@ -759,14 +792,21 @@ workerInstance.onexit = function() { ...@@ -759,14 +792,21 @@ workerInstance.onexit = function() {
```js ```js
// worker.js // worker.js
import worker from '@ohos.worker'; import worker from '@ohos.worker';
// 创建worker线程中与主线程通信的对象
const parentPort = worker.parentPort const parentPort = worker.parentPort
// worker线程接收主线程信息
parentPort.onmessage = function(e) { parentPort.onmessage = function(e) {
// data:主线程发送的信息
let data = e.data; let data = e.data;
console.log("worker.js onmessage"); console.log("worker.js onmessage");
// worker线程向主线程发送信息
parentPort.postMessage("123") parentPort.postMessage("123")
} }
// worker线程发生error的回调
parentPort.onerror= function(e) { parentPort.onerror= function(e) {
console.log("worker.js onerror"); console.log("worker.js onerror");
} }
...@@ -781,7 +821,3 @@ build-profile.json5 配置: ...@@ -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
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册