0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

鴻蒙語(yǔ)言基礎(chǔ)類庫(kù):ohos.worker 啟動(dòng)一個(gè)Worker

jf_46214456 ? 來(lái)源:jf_46214456 ? 作者:jf_46214456 ? 2024-07-11 17:03 ? 次閱讀

啟動(dòng)一個(gè)Worker

說明: 本模塊首批接口從API version 7開始支持。后續(xù)版本的新增接口,采用上角標(biāo)單獨(dú)標(biāo)記接口的起始版本。 開發(fā)前請(qǐng)熟悉鴻蒙開發(fā)指導(dǎo)文檔 :[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

Worker是與主線程并行的獨(dú)立線程。創(chuàng)建Worker的線程稱之為宿主線程,Worker自身的線程稱之為Worker線程。創(chuàng)建Worker傳入的url文件在Worker線程中執(zhí)行,可以處理耗時(shí)操作但不可以直接操作UI。

導(dǎo)入模塊

import worker from '@ohos.worker';

屬性

系統(tǒng)能力: 以下各項(xiàng)對(duì)應(yīng)的系統(tǒng)能力均為SystemCapability.Utils.Lang。

名稱參數(shù)類型可讀可寫說明
parentPort[DedicatedWorkerGlobalScope]worker線程用于與宿主線程通信的對(duì)象。

WorkerOptions

Worker構(gòu)造函數(shù)的選項(xiàng)信息,用于為Worker添加其他信息。

系統(tǒng)能力: 以下各項(xiàng)對(duì)應(yīng)的系統(tǒng)能力均為SystemCapability.Utils.Lang。

名稱參數(shù)類型可讀可寫說明
type"classic"按照指定方式執(zhí)行腳本。
namestringWorker的名稱。

Worker

使用以下方法前,均需先構(gòu)造Worker實(shí)例,Worker類繼承[EventTarget]。

constructor

constructor(scriptURL: string, options?: WorkerOptions)

Worker構(gòu)造函數(shù)。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
scriptURLstringWorker執(zhí)行腳本的url,路徑規(guī)范:若DevEco新建工程在pages同級(jí)下沒有workers目錄,需要新建workers目錄,將腳本文件放入workers目錄。
options[WorkerOptions]Worker構(gòu)造的選項(xiàng)。

返回值:

類型說明
Worker執(zhí)行Worker構(gòu)造函數(shù)生成的Worker對(duì)象,失敗則返回undefined。

示例:

const workerInstance = new worker.Worker("workers/worker.js", {name:"first worker"});

postMessage

postMessage(message: Object, options?: PostMessageOptions): void

向Worker線程發(fā)送消息,數(shù)據(jù)的傳輸采用結(jié)構(gòu)化克隆算法。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
messageObject發(fā)送至Worker的數(shù)據(jù)。
options[PostMessageOptions]可轉(zhuǎn)移對(duì)象是 ArrayBuffer 的實(shí)例對(duì)象。transferList數(shù)組中不可傳入null。

示例:

const workerInstance = new worker.Worker("workers/worker.js");
workerInstance.postMessage("hello world");
const workerInstance= new worker.Worker("workers/worker.js");
var buffer = new ArrayBuffer(8);
workerInstance.postMessage(buffer, [buffer]);

on

on(type: string, listener: EventListener): void

向Worker添加一個(gè)事件監(jiān)聽。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
typestring監(jiān)聽事件的type。
listener[EventListener]回調(diào)的事件。

示例:

const workerInstance = new worker.Worker("workers/worker.js")
workerInstance.on("alert", (e)= >{
    console.log("alert listener callback");
})

once

once(type: string, listener: EventListener): void

向Worker添加一個(gè)事件監(jiān)聽,事件監(jiān)聽只執(zhí)行一次便自動(dòng)刪除。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
typestring監(jiān)聽事件的type。
listener[EventListener]回調(diào)的事件。

示例:

const workerInstance = new worker.Worker("workers/worker.js");
workerInstance.once("alert", (e)= >{
    console.log("alert listener callback");
})

off

off(type: string, listener?: EventListener): void

刪除Worker的事件監(jiān)聽。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
typestring需要?jiǎng)h除事件的type。
listener[EventListener]需要?jiǎng)h除的回調(diào)的事件。

示例:

const workerInstance = new worker.Worker("workers/worker.js");
workerInstance.off("alert");

terminate

terminate(): void

關(guān)閉Worker線程,終止Worker接收消息。

系統(tǒng)能力: SystemCapability.Utils.Lang

示例:

const workerInstance = new worker.Worker("workers/worker.js")
workerInstance.terminate()

onexit

onexit?: (code: number) => void

Worker對(duì)象的onexit屬性表示W(wǎng)orker退出時(shí)被調(diào)用的事件處理程序,處理程序在宿主線程中執(zhí)行。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
codenumberWorker退出的code。

示例:

const workerInstance = new worker.Worker("workers/worker.js")
workerInstance.onexit = function(e) {
    console.log("onexit")
}

onerror

onerror?: (err: ErrorEvent) => void

Worker對(duì)象的onerror屬性表示W(wǎng)orker在執(zhí)行過程中發(fā)生異常被調(diào)用的事件處理程序,處理程序在宿主線程中執(zhí)行。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
err[ErrorEvent]異常數(shù)據(jù)。

示例:

const workerInstance = new worker.Worker("workers/worker.js")
workerInstance.onerror = function(e) {
    console.log("onerror")
}

onmessage

onmessage?: (event: MessageEvent) => void

Worker對(duì)象的onmessage屬性表示宿主線程接收到來(lái)自其創(chuàng)建的Worker通過parentPort.postMessage接口發(fā)送的消息時(shí)被調(diào)用的事件處理程序,處理程序在宿主線程中執(zhí)行。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
event[MessageEvent]收到的Worker消息數(shù)據(jù)。

示例:

const workerInstance = new worker.Worker("workers/worker.js")
workerInstance.onmessage = function(e) {
    console.log("onerror")
}

onmessageerror

onmessageerror?: (event: MessageEvent) => void

Worker對(duì)象的onmessageerror屬性表示當(dāng)Worker對(duì)象接收到一條無(wú)法被序列化的消息時(shí)被調(diào)用的事件處理程序,處理程序在宿主線程中執(zhí)行。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
event[MessageEvent]異常數(shù)據(jù)。

示例:

const workerInstance = new worker.Worker("workers/worker.js")
workerInstance.onmessageerror= function(e) {
    console.log("onmessageerror")
}

EventTarget

addEventListener

addEventListener(type: string, listener: EventListener): void

向Worker添加一個(gè)事件監(jiān)聽。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
typestring監(jiān)聽事件的type。
listener[EventListener]回調(diào)的事件。

示例:

const workerInstance = new worker.Worker("workers/worker.js")
workerInstance.addEventListener("alert", (e)= >{
    console.log("alert listener callback");
})

removeEventListener

removeEventListener(type: string, callback?: EventListener): void

刪除Worker的事件監(jiān)聽。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
typestring需要?jiǎng)h除事件的type。
callback[EventListener]需要?jiǎng)h除的回調(diào)的事件。

示例:

const workerInstance = new worker.Worker("workers/worker.js")
workerInstance.removeEventListener("alert")

dispatchEvent

dispatchEvent(event: Event): boolean

分發(fā)定義在Worker的事件。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
event[Event]需要分發(fā)的事件。

返回值:

類型說明
boolean分發(fā)的結(jié)果,false表示分發(fā)失敗。

示例:

const workerInstance = new worker.Worker("workers/worker.js")
workerInstance.dispatchEvent({type:"alert"})

removeAllListener

removeAllListener(): void

刪除Worker的所有事件監(jiān)聽。

系統(tǒng)能力: SystemCapability.Utils.Lang

示例:

const workerInstance = new worker.Worker("workers/worker.js")
workerInstance.removeAllListener({type:"alert"})

DedicatedWorkerGlobalScope

Worker線程用于與宿主線程通信的類,通過postMessage接口發(fā)送消息給宿主線程、close接口關(guān)閉Worker線程,DedicatedWorkerGlobalScope類繼承[WorkerGlobalScope]。

postMessage

postMessage(message: Object, options?: PostMessageOptions): void

Worker向宿主線程發(fā)送消息。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
messageObject發(fā)送至Worker的數(shù)據(jù)。
options[PostMessageOptions]可轉(zhuǎn)移對(duì)象是ArrayBuffer的實(shí)例對(duì)象。transferList數(shù)組中不可傳入null。

示例:

// main.js
import worker from '@ohos.worker';
const workerInstance = new worker.Worker("workers/worker.js")
workerInstance.postMessage("hello world")
workerInstance.onmessage = function(e) {
    console.log("receive data from worker.js")
}
// worker.js
import worker from '@ohos.worker';
const parentPort = worker.parentPort;
parentPort.onmessage = function(e){
    parentPort.postMessage("receive data from main.js")
}

close

close(): void

關(guān)閉Worker線程,終止Worker接收消息。

系統(tǒng)能力: SystemCapability.Utils.Lang

示例:

// main.js
import worker from '@ohos.worker';
const workerInstance = new worker.Worker("workers/worker.js")
// worker.js
import worker from '@ohos.worker';
const parentPort = worker.parentPort;
parentPort.onmessage = function(e) {
    parentPort.close()
}

onmessage

onmessage?: (event: MessageEvent) => void

DedicatedWorkerGlobalScope的onmessage屬性表示W(wǎng)orker線程收到來(lái)自其宿主線程通過worker.postMessage接口發(fā)送的消息時(shí)被調(diào)用的事件處理程序,處理程序在Worker線程中執(zhí)行。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
event[MessageEvent]收到的Worker消息數(shù)據(jù)。

示例:

// main.js
import worker from '@ohos.worker';
const workerInstance = new worker.Worker("workers/worker.js")
workerInstance.postMessage("hello world")
// worker.js
import worker from '@ohos.worker';
const parentPort = worker.parentPort;
parentPort.onmessage = function(e) {
    console.log("receive main.js message")
}

onmessageerror

onmessageerror?: (event: MessageEvent) => void

DedicatedWorkerGlobalScope的onmessageerror屬性表示當(dāng)Worker對(duì)象接收到一條無(wú)法被反序列化的消息時(shí)被調(diào)用的事件處理程序,處理程序在Worker線程中執(zhí)行。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
event[MessageEvent]異常數(shù)據(jù)。

示例:

// main.js
import worker from '@ohos.worker';
const workerInstance = new worker.Worker("workers/worker.js")
// worker.js
import worker from '@ohos.worker';
const parentPort = worker.parentPort;
parentPort.onmessageerror= function(e) {
    console.log("worker.js onmessageerror")
}

PostMessageOptions

明確數(shù)據(jù)傳遞過程中需要轉(zhuǎn)移所有權(quán)對(duì)象的類,傳遞所有權(quán)的對(duì)象必須是ArrayBuffer。

系統(tǒng)能力: 以下各項(xiàng)對(duì)應(yīng)的系統(tǒng)能力均為SystemCapability.Utils.Lang。

名稱參數(shù)類型可讀可寫說明
transferObject[]ArrayBuffer數(shù)組,用于傳遞所有權(quán)。

Event

事件類。

系統(tǒng)能力: 以下各項(xiàng)對(duì)應(yīng)的系統(tǒng)能力均為SystemCapability.Utils.Lang。

名稱參數(shù)類型可讀可寫說明
typestring指定事件的type。
timeStampnumber事件創(chuàng)建時(shí)的時(shí)間戳(精度為毫秒)。

EventListener

事件監(jiān)聽類。

(evt: Event): void | Promise

執(zhí)行的回調(diào)函數(shù)。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
evt[Event]回調(diào)的事件類。

返回值:

類型說明
voidPromise

示例:

const workerInstance = new worker.Worker("workers/worker.js");
workerInstance.addEventListener("alert", (e)= >{
    console.log("alert listener callback");
})

ErrorEvent

錯(cuò)誤事件類,用于表示W(wǎng)orker執(zhí)行過程中出現(xiàn)異常的詳細(xì)信息,ErrorEvent類繼承[Event]。

系統(tǒng)能力: 以下各項(xiàng)對(duì)應(yīng)的系統(tǒng)能力均為SystemCapability.Utils.Lang。

名稱參數(shù)類型可讀可寫說明
messagestring異常發(fā)生的錯(cuò)誤信息。
filenamestring出現(xiàn)異常所在的文件。
linenonumber異常所在的行數(shù)。
colnonumber異常所在的列數(shù)。
errorObject異常類型。

MessageEvent

消息類,持有Worker線程間傳遞的數(shù)據(jù)。

系統(tǒng)能力: 以下各項(xiàng)對(duì)應(yīng)的系統(tǒng)能力均為SystemCapability.Utils.Lang。

名稱參數(shù)類型可讀可寫說明
dataT線程間傳遞的數(shù)據(jù)。

WorkerGlobalScope

Worker線程自身的運(yùn)行環(huán)境,WorkerGlobalScope類繼承[EventTarget]。

屬性

系統(tǒng)能力: 以下各項(xiàng)對(duì)應(yīng)的系統(tǒng)能力均為SystemCapability.Utils.Lang。

QQ截圖20240705210937.png

名稱參數(shù)類型HarmonyOSOpenHarmony鴻蒙文檔籽料:mau123789是v直接拿可讀可寫說明
namestringWorker的名字,有new Worker時(shí)指定。
self[WorkerGlobalScope] & typeof globalThisWorkerGlobalScope本身。

onerror

onerror?: (ev: ErrorEvent) => void

WorkerGlobalScope的onerror屬性表示W(wǎng)orker在執(zhí)行過程中發(fā)生異常被調(diào)用的事件處理程序,處理程序在Worker線程中執(zhí)行。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
ev[ErrorEvent]異常數(shù)據(jù)。

示例:

// main.js
import worker from '@ohos.worker';
const workerInstance = new worker.Worker("workers/worker.js")
// worker.js
import worker from '@ohos.worker';
const parentPort = worker.parentPort
parentPort.onerror = function(e){
    console.log("worker.js onerror")
}

審核編輯 黃宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Worker
    +關(guān)注

    關(guān)注

    0

    文章

    8

    瀏覽量

    6548
  • 鴻蒙
    +關(guān)注

    關(guān)注

    57

    文章

    2474

    瀏覽量

    43686
收藏 0人收藏

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    鴻蒙OS開發(fā)案例:【ArkTS庫(kù)多線程CPU密集型任務(wù)Worker

    通過某地區(qū)提供的房?jī)r(jià)數(shù)據(jù)訓(xùn)練個(gè)簡(jiǎn)易的房?jī)r(jià)預(yù)測(cè)模型,該模型支持通過輸入房屋面積和房間數(shù)量去預(yù)測(cè)該區(qū)域的房?jī)r(jià),模型需要長(zhǎng)時(shí)間運(yùn)行,房?jī)r(jià)預(yù)測(cè)需要使用前面的模型運(yùn)行結(jié)果,因此需要使用Worker。
    的頭像 發(fā)表于 04-01 21:55 ?1371次閱讀
    <b class='flag-5'>鴻蒙</b>OS開發(fā)案例:【ArkTS<b class='flag-5'>類</b><b class='flag-5'>庫(kù)</b>多線程CPU密集型任務(wù)<b class='flag-5'>Worker</b>】

    ArkTS語(yǔ)言基礎(chǔ)庫(kù)-解析

    被設(shè)計(jì)用來(lái)傳輸和存儲(chǔ)數(shù)據(jù),是種可擴(kuò)展標(biāo)記語(yǔ)言。語(yǔ)言基礎(chǔ)庫(kù)提供了[XML生成、解析與轉(zhuǎn)換]的能力。 URL、URI構(gòu)造和解析能力:其中[U
    發(fā)表于 02-20 16:44

    鴻蒙原生應(yīng)用開發(fā)-ArkTS語(yǔ)言基礎(chǔ)庫(kù)概述

    擴(kuò)展標(biāo)記語(yǔ)言。語(yǔ)言基礎(chǔ)庫(kù)提供了XML生成、解析與轉(zhuǎn)換的能力。 URL、URI構(gòu)造和解析能力:其中URI是統(tǒng)資源標(biāo)識(shí)符,可以唯
    發(fā)表于 03-05 15:42

    鴻蒙原生應(yīng)用開發(fā)-ArkTS語(yǔ)言基礎(chǔ)庫(kù)多線程TaskPool和Worker的對(duì)比(

    TaskPool(任務(wù)池)和Worker的作用是為應(yīng)用程序提供個(gè)多線程的運(yùn)行環(huán)境,用于處理耗時(shí)的計(jì)算任務(wù)或其他密集型任務(wù)??梢杂行У乇苊膺@些任務(wù)阻塞主線程,從而最大化系統(tǒng)的利用率,降低整體資源消耗
    發(fā)表于 03-25 14:11

    鴻蒙原生應(yīng)用開發(fā)-ArkTS語(yǔ)言基礎(chǔ)庫(kù)多線程TaskPool和Worker的對(duì)比(二)

    易用,支持任務(wù)的執(zhí)行、取消。工作線程數(shù)量上限為4。 Worker運(yùn)作機(jī)制 圖2 Worker運(yùn)作機(jī)制示意圖 創(chuàng)建Worker的線程稱為宿主線程(不定是主線程,工作線程也支持創(chuàng)建
    發(fā)表于 03-26 15:25

    鴻蒙原生應(yīng)用開發(fā)-ArkTS語(yǔ)言基礎(chǔ)庫(kù)多線程TaskPool和Worker的對(duì)比(三)

    import worker from \'@ohos.worker\'; // 寫法 // Stage模型-目錄同級(jí)(entry模塊下,workers目錄與pages目錄同級(jí)) const
    發(fā)表于 03-27 16:26

    HarmonyOS NEXT 原生應(yīng)用/元服務(wù)-ArkTS代碼調(diào)試worker/taskpool調(diào)試

    代碼后,在 worker 文件中設(shè)置斷點(diǎn)。 啟動(dòng)調(diào)試,當(dāng)斷點(diǎn)命中時(shí),調(diào)試窗口會(huì)新啟動(dòng)個(gè)調(diào)試會(huì)話,顯示
    發(fā)表于 03-13 17:46

    HarmonyOS CPU與I/O密集型任務(wù)開發(fā)指導(dǎo)

    。 基于多線程并發(fā)機(jī)制處理CPU密集型任務(wù)可以提高CPU利用率,提升應(yīng)用程序響應(yīng)速度。 當(dāng)進(jìn)行系列同步任務(wù)時(shí),推薦使用Worker;而進(jìn)行大量或調(diào)度點(diǎn)較為分散的獨(dú)立任務(wù)時(shí),不方便使用8個(gè)Wo
    發(fā)表于 09-26 16:29

    HarmonyOS語(yǔ)言基礎(chǔ)庫(kù)開發(fā)指南上線啦!

    語(yǔ)言基礎(chǔ)庫(kù)提供哪些功能?多線程并發(fā)如何實(shí)現(xiàn)?TaskPool(任務(wù)池)和Worker在實(shí)現(xiàn)和使用場(chǎng)景上有何不同? 針對(duì)開發(fā)者關(guān)注的并發(fā)等語(yǔ)言
    發(fā)表于 10-18 16:36

    面向?qū)ο笄度胧綄?shí)時(shí)操作系統(tǒng)Worker1.0

    Worker1.0繼承圖1 Worker1.0主要的簡(jiǎn)介3 Worker1.0 API4 Worker1.0移植9
    發(fā)表于 04-29 18:01 ?39次下載
    面向?qū)ο笄度胧綄?shí)時(shí)操作系統(tǒng)<b class='flag-5'>Worker</b>1.0

    normal worker_pool詳細(xì)的創(chuàng)建過程代碼分析

    默認(rèn) work 是在 normal worker_pool 中處理的。系統(tǒng)的規(guī)劃是每個(gè) CPU 創(chuàng)建兩個(gè) normal worker_pool:個(gè)
    的頭像 發(fā)表于 04-08 14:35 ?7635次閱讀
    normal <b class='flag-5'>worker</b>_pool詳細(xì)的創(chuàng)建過程代碼分析

    Tokio中hang死所有worker的方法

    原因是 tokio 里的待執(zhí)行 task 不是簡(jiǎn)單的放到個(gè) queue 里,除了 runtime 內(nèi)共享的,可被每個(gè) worker 消費(fèi)的run_queue[2],每個(gè) worker
    的頭像 發(fā)表于 02-03 16:26 ?1126次閱讀

    HarmonyOS語(yǔ)言基礎(chǔ)庫(kù)開發(fā)指南上線啦!

    語(yǔ)言基礎(chǔ)庫(kù)提供哪些功能?多線程并發(fā)如何實(shí)現(xiàn)?TaskPool(任務(wù)池)和Worker在實(shí)現(xiàn)和使用場(chǎng)景上有何不同? 針對(duì)開發(fā)者關(guān)注的并發(fā)等語(yǔ)言
    的頭像 發(fā)表于 10-18 16:20 ?773次閱讀
    HarmonyOS<b class='flag-5'>語(yǔ)言</b>基礎(chǔ)<b class='flag-5'>類</b><b class='flag-5'>庫(kù)</b>開發(fā)指南上線啦!

    鴻蒙APP開發(fā):【ArkTS庫(kù)多線程】TaskPool和Worker的對(duì)比

    TaskPool(任務(wù)池)和Worker的作用是為應(yīng)用程序提供個(gè)多線程的運(yùn)行環(huán)境,用于處理耗時(shí)的計(jì)算任務(wù)或其他密集型任務(wù)??梢杂行У乇苊膺@些任務(wù)阻塞主線程,從而最大化系統(tǒng)的利用率,降低整體資源消耗,并提高系統(tǒng)的整體性能。
    的頭像 發(fā)表于 03-26 22:09 ?859次閱讀
    <b class='flag-5'>鴻蒙</b>APP開發(fā):【ArkTS<b class='flag-5'>類</b><b class='flag-5'>庫(kù)</b>多線程】TaskPool和<b class='flag-5'>Worker</b>的對(duì)比

    鴻蒙APP開發(fā):【ArkTS庫(kù)多線程】TaskPool和Worker的對(duì)比(2)

    創(chuàng)建Worker的線程稱為宿主線程(不定是主線程,工作線程也支持創(chuàng)建Worker子線程),Worker自身的線程稱為Worker子線程(或
    的頭像 發(fā)表于 03-27 15:44 ?681次閱讀
    <b class='flag-5'>鴻蒙</b>APP開發(fā):【ArkTS<b class='flag-5'>類</b><b class='flag-5'>庫(kù)</b>多線程】TaskPool和<b class='flag-5'>Worker</b>的對(duì)比(2)

    電子發(fā)燒友

    中國(guó)電子工程師最喜歡的網(wǎng)站

    • 2931785位工程師會(huì)員交流學(xué)習(xí)
    • 獲取您個(gè)性化的科技前沿技術(shù)信息
    • 參加活動(dòng)獲取豐厚的禮品