99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

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

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

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

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

jf_46214456 ? 來源:jf_46214456 ? 作者:jf_46214456 ? 2024-03-26 22:09 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

本文將從實(shí)現(xiàn)特點(diǎn)和適用場景兩個(gè)方面來進(jìn)行TaskPool與Worker的比較,同時(shí)提供了各自運(yùn)作機(jī)制和注意事項(xiàng)的相關(guān)說明。

一、實(shí)現(xiàn)特點(diǎn)對比

表1 TaskPool和Worker的實(shí)現(xiàn)特點(diǎn)對比

實(shí)現(xiàn)TaskPoolWorker
內(nèi)存模型線程間隔離,內(nèi)存不共享。線程間隔離,內(nèi)存不共享。
參數(shù)傳遞機(jī)制采用標(biāo)準(zhǔn)的結(jié)構(gòu)化克隆算法(Structured Clone)進(jìn)行序列化、反序列化,完成參數(shù)傳遞。支持ArrayBuffer轉(zhuǎn)移和SharedArrayBuffer共享。采用標(biāo)準(zhǔn)的結(jié)構(gòu)化克隆算法(Structured Clone)進(jìn)行序列化、反序列化,完成參數(shù)傳遞。支持ArrayBuffer轉(zhuǎn)移和SharedArrayBuffer共享。
參數(shù)傳遞直接傳遞,無需封裝,默認(rèn)進(jìn)行transfer。消息對象唯一參數(shù),需要自己封裝。
方法調(diào)用直接將方法傳入調(diào)用。在Worker線程中進(jìn)行消息解析并調(diào)用對應(yīng)方法。
返回值異步調(diào)用后默認(rèn)返回。主動發(fā)送消息,需在onmessage解析賦值。
生命周期TaskPool自行管理生命周期,無需關(guān)心任務(wù)負(fù)載高低。開發(fā)者自行管理Worker的數(shù)量及生命周期。
任務(wù)池個(gè)數(shù)上限自動管理,無需配置。同個(gè)進(jìn)程下,最多支持同時(shí)開啟8個(gè)Worker線程。
任務(wù)執(zhí)行時(shí)長上限無限制。無限制。
設(shè)置任務(wù)的優(yōu)先級不支持。不支持。
執(zhí)行任務(wù)的取消支持取消任務(wù)隊(duì)列中等待的任務(wù)。不支持。
鴻蒙開發(fā)應(yīng)用知識更新庫gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md在這。或+mau123789學(xué)習(xí),是v喔

搜狗高速瀏覽器截圖20240326151547.png

二、適用場景對比

TaskPool偏向獨(dú)立任務(wù)維度,該任務(wù)在線程中執(zhí)行,無需關(guān)注線程的生命周期,超長任務(wù)(大于3分鐘)會被系統(tǒng)自動回收;而Worker偏向線程的維度,支持長時(shí)間占據(jù)線程執(zhí)行,需要主動管理線程生命周期。

常見的一些開發(fā)場景及適用具體說明如下:

有關(guān)聯(lián)的一系列同步任務(wù)。例如在一些需要?jiǎng)?chuàng)建、使用句柄的場景中,句柄創(chuàng)建每次都是不同的,該句柄需永久保存,保證使用該句柄進(jìn)行操作,需要使用Worker。

需要頻繁取消的任務(wù)。例如圖庫大圖瀏覽場景,為提升體驗(yàn),會同時(shí)緩存當(dāng)前圖片左右側(cè)各2張圖片,往一側(cè)滑動跳到下一張圖片時(shí),要取消另一側(cè)的一個(gè)緩存任務(wù),需要使用TaskPool。

大量或者調(diào)度點(diǎn)較分散的任務(wù)。例如大型應(yīng)用的多個(gè)模塊包含多個(gè)耗時(shí)任務(wù),不方便使用8個(gè)Worker去做負(fù)載管理,推薦采用TaskPool。

審核編輯 黃宇

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

    關(guān)注

    0

    文章

    8

    瀏覽量

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

    關(guān)注

    60

    文章

    2620

    瀏覽量

    44063
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

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

    多線程的安全注意事項(xiàng)

    多線程安全是指多個(gè)線程同時(shí)訪問或修改共享資源時(shí),能夠保證程序的正確性和可靠性。 開發(fā)者選擇TaskPoolWorker進(jìn)行
    發(fā)表于 06-20 07:49

    同步任務(wù)開發(fā)指導(dǎo)

    ,例如無法單例創(chuàng)建的對象實(shí)現(xiàn)的方法。 使用TaskPool處理同步任務(wù) 當(dāng)調(diào)度獨(dú)立的任務(wù),或者一系列任務(wù)為靜態(tài)方法實(shí)現(xiàn),或者可以通過單例構(gòu)造唯一的句柄或對象,可在不同任務(wù)線程之間
    發(fā)表于 06-19 07:57

    CPU密集型任務(wù)開發(fā)指導(dǎo)

    密集型任務(wù)可以提高CPU利用率,提升應(yīng)用程序響應(yīng)速度。 當(dāng)任務(wù)不需要長時(shí)間(3分鐘)占據(jù)后臺線程,而是一個(gè)個(gè)獨(dú)立的任務(wù)時(shí),推薦使用TaskPool,反之推薦使用Worker。接下來將以圖像直方圖處理
    發(fā)表于 06-19 06:05

    TaskPoolWorker對比分析

    支持。不支持。適用場景對比 TaskPoolWorker均支持多線程并發(fā)能力。由于TaskPool的工作
    發(fā)表于 06-18 06:43

    什么是ArkTS?

    、提高系統(tǒng)的整體性能,開發(fā)者無需關(guān)心線程實(shí)例的生命周期。 Worker支持多線程并發(fā),支持Worker
    發(fā)表于 06-17 06:24

    鴻蒙5開發(fā)寶藏案例分享---跨線程性能優(yōu)化指南

    ;>Worker</span>做多線程開發(fā)時(shí),總遇到對象跨線程卡頓的問題,原來鴻蒙早就提供了解決方案。下面結(jié)合代碼和實(shí)戰(zhàn)案
    發(fā)表于 06-12 17:13

    鴻蒙5開發(fā)寶藏案例分享---性能體驗(yàn)設(shè)計(jì)

    例子: // 錯(cuò)誤示范:直接在主線程加載大圖 Image($r(\'app.media.large_img\')) // 可能造成界面凍結(jié) // 正確做法:異步加載+占位符 Column
    發(fā)表于 06-12 16:45

    鴻蒙5開發(fā)寶藏案例分享---應(yīng)用并發(fā)設(shè)計(jì)

    ?** 鴻蒙并發(fā)編程實(shí)戰(zhàn)指南:解鎖ArkTS多線程黑科技** 嘿,開發(fā)者朋友們! 今天給大家扒一扒鴻蒙官方文檔里藏著的并發(fā)編程寶藏—— 10
    發(fā)表于 06-12 16:19

    使用DevEcoStudio 開發(fā)、編譯鴻蒙 NEXT_APP 以及使用中文插件

    # 使用DevEcoStudio 開發(fā)、編譯鴻蒙 NEXT_APP 以及使用中文插件 #鴻蒙開發(fā)工具 #DevEco Studio ##
    發(fā)表于 06-11 17:18

    開源啦?。?!基于鴻蒙ArkTS封裝的圖表組件《McCharts》,大家快來一起共創(chuàng)

    也用鴻蒙ArkTS語法嘗試開發(fā)了一些APP,雖然還沒上架哈,不過基本的開發(fā)流程以及交互都熟悉了,而且馬上第一款
    發(fā)表于 03-15 15:21

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

    開發(fā)者可通過在workertaskpool代碼上設(shè)置斷點(diǎn),對worker/taskpool進(jìn)行斷點(diǎn)調(diào)試。 一、
    發(fā)表于 03-13 17:46

    鴻蒙文件傳輸三方上線開源鴻蒙社區(qū) 十行代碼實(shí)現(xiàn)大文件高速傳輸

    近日,華為在OpenHarmony社區(qū)上線了“super_fast_file_trans”文件傳輸三方(以下簡稱“SFFT”)。這一三方的推出,為開發(fā)者提供了一套支持大文件多線程
    發(fā)表于 03-06 10:29

    socket 多線程編程實(shí)現(xiàn)方法

    在現(xiàn)代網(wǎng)絡(luò)編程中,多線程技術(shù)被廣泛應(yīng)用于提高服務(wù)器的并發(fā)處理能力。Socket編程是網(wǎng)絡(luò)通信的基礎(chǔ),而將多線程技術(shù)應(yīng)用于Socket編程,可以顯著提升服務(wù)器的性能。 多線程編程的基本概念 多線
    的頭像 發(fā)表于 11-12 14:16 ?1016次閱讀

    鴻蒙原生應(yīng)用元服務(wù)開發(fā)-倉頡ArkTS相互操作(二)

    = data.getId() console.log(\"id is \" + id) 十二、ArkTS 互操作和倉頡多線程 ArkTS 是單線程執(zhí)行的虛擬機(jī),在運(yùn)行時(shí)上沒有對
    發(fā)表于 08-01 11:01

    鴻蒙原生應(yīng)用元服務(wù)開發(fā)-倉頡ArkTS相互操作(一)

    ArkTS 運(yùn)行時(shí)接口,為用戶提供級別的 ArkTS 互操作能力。一、使用場景: 1.在 ArkTS 應(yīng)用開發(fā)倉頡模塊:把用戶倉頡代碼封
    發(fā)表于 07-31 17:43