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

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

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

鴻蒙OS開發(fā)實例:【ArkTS類庫多線程@Concurrent裝飾器校驗并發(fā)函數(shù)】

jf_46214456 ? 來源:jf_46214456 ? 作者:jf_46214456 ? 2024-04-02 14:45 ? 次閱讀

在使用TaskPool時,執(zhí)行的并發(fā)函數(shù)需要使用該裝飾器修飾,否則無法通過相關(guān)校驗。從API version 9開始,該裝飾器支持在ArkTS卡片中使用。

裝飾器說明

@Concurrent并發(fā)裝飾器說明
裝飾器參數(shù)無。
使用場景僅支持在Stage模型的工程中使用。
裝飾的函數(shù)類型允許標注async函數(shù)或普通函數(shù)。禁止標注generator、箭頭函數(shù)、method。不支持類成員函數(shù)或者匿名函數(shù)。
裝飾的函數(shù)內(nèi)的變量類型允許使用local變量、入?yún)⒑屯ㄟ^import引入的變量。禁止使用閉包變量。

裝飾器使用示例

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

鴻蒙NEXT學(xué)習文檔+mau123789是v喔1
import taskpool from '@ohos.taskpool';

@Concurrent
function add(num1: number, num2: number): number {
  return num1 + num2;
}

async function ConcurrentFunc(): Promise< void > {
  try {
    let task: taskpool.Task = new taskpool.Task(add, 1, 2);
    console.info("taskpool res is: " + await taskpool.execute(task));
  } catch (e) {
    console.error("taskpool execute error is: " + e);
  }
}

@Entry
@Component
struct Index {
  @State message: string = 'Hello World'

  build() {
    Row() {
      Column() {
        Text(this.message)
          .fontSize(50)
          .fontWeight(FontWeight.Bold)
          .onClick(() = > {
            ConcurrentFunc();
          })
      }
      .width('100%')
    }
    .height('100%')
  }
}

審核編輯 黃宇

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

    關(guān)注

    0

    文章

    278

    瀏覽量

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

    關(guān)注

    57

    文章

    2352

    瀏覽量

    42858
  • 鴻蒙OS
    +關(guān)注

    關(guān)注

    0

    文章

    188

    瀏覽量

    4391
收藏 人收藏

    評論

    相關(guān)推薦

    鴻蒙OS開發(fā)實例:【ArkTS多線程CPU密集型任務(wù)TaskPool】

    CPU密集型任務(wù)是指需要占用系統(tǒng)資源處理大量計算能力的任務(wù),需要長時間運行,這段時間會阻塞線程其它事件的處理,不適宜放在主線程進行。例如圖像處理、視頻編碼、數(shù)據(jù)分析等。 基于多線程并發(fā)
    的頭像 發(fā)表于 04-01 22:25 ?844次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>OS</b><b class='flag-5'>開發(fā)</b><b class='flag-5'>實例</b>:【<b class='flag-5'>ArkTS</b><b class='flag-5'>類</b><b class='flag-5'>庫</b><b class='flag-5'>多線程</b>CPU密集型任務(wù)TaskPool】

    ArkTS語言基礎(chǔ)-解析

    ArkTS語言基礎(chǔ)是HarmonyOS系統(tǒng)上為應(yīng)用開發(fā)者提供的常用基礎(chǔ)能力,主要包含能力如下圖所示。 圖1 ArkTS語言基礎(chǔ)
    發(fā)表于 02-20 16:44

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

    ArkTS語言基礎(chǔ)是HarmonyOS系統(tǒng)上為應(yīng)用開發(fā)者提供的常用基礎(chǔ)能力,主要包含能力如下圖所示。 1.提供異步并發(fā)
    發(fā)表于 03-05 15:42

    鴻蒙原生應(yīng)用開發(fā)-ArkTS語言基礎(chǔ)多線程@Concurrent裝飾校驗并發(fā)函數(shù)

    在使用TaskPool時,執(zhí)行的并發(fā)函數(shù)需要使用該裝飾修飾,否則無法通過相關(guān)校驗。從API version 9開始,該裝飾
    發(fā)表于 03-18 10:30

    鴻蒙原生應(yīng)用開發(fā)-ArkTS語言基礎(chǔ)多線程CPU密集型任務(wù)TaskPool

    CPU密集型任務(wù)是指需要占用系統(tǒng)資源處理大量計算能力的任務(wù),需要長時間運行,這段時間會阻塞線程其它事件的處理,不適宜放在主線程進行。例如圖像處理、視頻編碼、數(shù)據(jù)分析等。 基于多線程并發(fā)
    發(fā)表于 03-19 14:14

    鴻蒙原生應(yīng)用開發(fā)-ArkTS語言基礎(chǔ)多線程I/O密集型任務(wù)開發(fā)

    filePath2 = ...; // 使用TaskPool執(zhí)行包含密集I/O的并發(fā)函數(shù) // 數(shù)組較大時,I/O密集型任務(wù)任務(wù)分發(fā)也會搶占主線程,需要使用多線程能力
    發(fā)表于 03-21 14:57

    鴻蒙原生應(yīng)用開發(fā)-ArkTS語言基礎(chǔ)多線程并發(fā)概述

    的一系列復(fù)雜偶發(fā)的問題,同時并發(fā)度也相對較高,因此得到了廣泛的支持和使用,也是當前ArkTS語言選擇的并發(fā)模型。 由于Actor模型的內(nèi)存隔離特性,所以需要進行跨線程的數(shù)據(jù)序列化傳輸。
    發(fā)表于 03-22 15:40

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

    一、TaskPool注意事項 實現(xiàn)任務(wù)的函數(shù)需要使用裝飾@Concurrent標注,且僅支持在.ets文件中使用。 實現(xiàn)任務(wù)的函數(shù)入?yún)⑿铦M
    發(fā)表于 03-27 16:26

    鴻蒙原生應(yīng)用開發(fā)-ArkTS語言基礎(chǔ)多線程并發(fā)概述

    的一系列復(fù)雜偶發(fā)的問題,同時并發(fā)度也相對較高,因此得到了廣泛的支持和使用,也是當前ArkTS語言選擇的并發(fā)模型。 由于Actor模型的內(nèi)存隔離特性,所以需要進行跨線程的數(shù)據(jù)序列化傳輸。
    發(fā)表于 03-28 14:35

    HarmonyOS使用多線程并發(fā)能力開發(fā)

    代表,不需要開發(fā)者去面對鎖帶來的一系列復(fù)雜偶發(fā)的問題,同時并發(fā)度也相對較高,因此得到了廣泛的支持和使用,也是當前ArkTS語言選擇的并發(fā)模型。 由于Actor模型的內(nèi)存隔離特性,所以需
    發(fā)表于 09-25 15:23

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

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

    鴻蒙 OS 應(yīng)用開發(fā)初體驗

    的 IDE、鴻蒙生態(tài)的開發(fā)語言 ArkTS,通過模擬運行起來了鴻蒙 OS 版 HelloWor
    發(fā)表于 11-02 19:38

    多線程并發(fā)查詢oracle數(shù)據(jù)

    多線程并發(fā)查詢Oracle數(shù)據(jù)是指在同一時間內(nèi)有多個線程同時執(zhí)行數(shù)據(jù)查詢操作。這種并發(fā)查詢的
    的頭像 發(fā)表于 11-17 14:22 ?3884次閱讀

    mfc多線程編程實例

    (圖形用戶界面)應(yīng)用程序的開發(fā)。在這篇文章中,我們將重點介紹MFC中的多線程編程。 多線程編程在軟件開發(fā)中非常重要,它可以實現(xiàn)程序的并發(fā)執(zhí)行
    的頭像 發(fā)表于 12-01 14:29 ?1507次閱讀

    鴻蒙OS開發(fā)實例:【ArkTS多線程I/O密集型任務(wù)開發(fā)

    使用異步并發(fā)可以解決單次I/O任務(wù)阻塞的問題,但是如果遇到I/O密集型任務(wù),同樣會阻塞線程中其它任務(wù)的執(zhí)行,這時需要使用多線程并發(fā)能力來進行解決。 I/O密集型任務(wù)的性能重點通常
    的頭像 發(fā)表于 04-01 16:32 ?521次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>OS</b><b class='flag-5'>開發(fā)</b><b class='flag-5'>實例</b>:【<b class='flag-5'>ArkTS</b><b class='flag-5'>類</b><b class='flag-5'>庫</b><b class='flag-5'>多線程</b>I/O密集型任務(wù)<b class='flag-5'>開發(fā)</b>】