在使用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引入的變量。禁止使用閉包變量。 |
裝飾器使用示例
鴻蒙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
發(fā)布評論請先 登錄
相關(guān)推薦
鴻蒙OS開發(fā)實例:【ArkTS類庫多線程CPU密集型任務(wù)TaskPool】
CPU密集型任務(wù)是指需要占用系統(tǒng)資源處理大量計算能力的任務(wù),需要長時間運行,這段時間會阻塞線程其它事件的處理,不適宜放在主線程進行。例如圖像處理、視頻編碼、數(shù)據(jù)分析等。
基于多線程并發(fā)
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ā)查詢的
mfc多線程編程實例
(圖形用戶界面)應(yīng)用程序的開發(fā)。在這篇文章中,我們將重點介紹MFC中的多線程編程。 多線程編程在軟件開發(fā)中非常重要,它可以實現(xiàn)程序的并發(fā)執(zhí)行
鴻蒙OS開發(fā)實例:【ArkTS類庫多線程I/O密集型任務(wù)開發(fā)】
使用異步并發(fā)可以解決單次I/O任務(wù)阻塞的問題,但是如果遇到I/O密集型任務(wù),同樣會阻塞線程中其它任務(wù)的執(zhí)行,這時需要使用多線程并發(fā)能力來進行解決。
I/O密集型任務(wù)的性能重點通常
評論