線程模型
線程類型
Stage模型下的線程主要有如下三類:
- 主線程
- 執(zhí)行UI繪制。
- 管理主線程的ArkTS引擎實(shí)例,使多個(gè)UIAbility組件能夠運(yùn)行在其之上。
- 管理其他線程的ArkTS引擎實(shí)例,例如使用TaskPool(任務(wù)池)創(chuàng)建任務(wù)或取消任務(wù)、啟動(dòng)和終止Worker線程。
- 分發(fā)交互事件。
- 處理應(yīng)用代碼的回調(diào),包括事件處理和生命周期管理。
- 接收TaskPool以及Worker線程發(fā)送的消息。
- [TaskPool Worker線程]
- 用于執(zhí)行耗時(shí)操作,支持設(shè)置調(diào)度優(yōu)先級(jí)、負(fù)載均衡等功能,推薦使用。
- [Worker線程]
- 用于執(zhí)行耗時(shí)操作,支持線程間通信。 TaskPool與Worker的運(yùn)作機(jī)制、通信手段和使用方法可以參考[TaskPool和Worker的對(duì)比]。
說(shuō)明:
開(kāi)發(fā)前請(qǐng)熟悉鴻蒙開(kāi)發(fā)指導(dǎo)文檔 :[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md
]
- TaskPool自行管理線程數(shù)量,其生命周期由TaskPool統(tǒng)一管理。Worker線程最多創(chuàng)建8個(gè),其生命周期由開(kāi)發(fā)者自行維護(hù)。
- 同一線程中存在多個(gè)組件,例如UIAbility組件和UI組件都存在于主線程中。在Stage模型中目前主要使用[EventHub]進(jìn)行數(shù)據(jù)通信。
- 執(zhí)行
hdc shell
命令,進(jìn)入設(shè)備的shell命令行。在shell命令行中,執(zhí)行ps -p -T
命令,可以查看指定應(yīng)用進(jìn)程的線程信息。其中,
為需要指定的應(yīng)用進(jìn)程的[進(jìn)程ID]。
使用EventHub進(jìn)行線程內(nèi)通信
[EventHub]提供了線程內(nèi)發(fā)送和處理事件的能力,包括對(duì)事件訂閱、取消訂閱、觸發(fā)事件等。以UIAbility組件與UI之間的數(shù)據(jù)同步為例,具體使用方法可以參考[UIAbility組件與UI的數(shù)據(jù)同步]。
審核編輯 黃宇
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。
舉報(bào)投訴
相關(guān)推薦
前言 在鴻蒙內(nèi)核中,廣義上可理解為一個(gè)Task就是一個(gè)線程 一、怎么理解Task 1. 官方文檔是怎么描述線程 基本概念 從系統(tǒng)的角度看,線程是競(jìng)爭(zhēng)系統(tǒng)資源的最小運(yùn)行單元。
發(fā)表于 10-18 10:42
?2216次閱讀
場(chǎng)景介紹 如果應(yīng)用的業(yè)務(wù)邏輯比較復(fù)雜,可能需要?jiǎng)?chuàng)建多個(gè)線程來(lái)執(zhí)行多個(gè)任務(wù)。這種情況下,代碼復(fù)雜難以維護(hù),任務(wù)與線程的交互也會(huì)更加繁雜。要解決此問(wèn)題,開(kāi)發(fā)者可以使用“TaskDispatcher”來(lái)
發(fā)表于 01-29 16:22
?843次閱讀
并發(fā)模型是用來(lái)實(shí)現(xiàn)不同應(yīng)用場(chǎng)景中并發(fā)任務(wù)的編程模型,常見(jiàn)的并發(fā)模型分為基于內(nèi)存共享的并發(fā)模型和基于消息通信的并發(fā)模型。
Actor并發(fā)
發(fā)表于 03-22 15:40
一、TaskPool注意事項(xiàng)
實(shí)現(xiàn)任務(wù)的函數(shù)需要使用裝飾器@Concurrent標(biāo)注,且僅支持在.ets文件中使用。
實(shí)現(xiàn)任務(wù)的函數(shù)入?yún)⑿铦M足序列化支持的類型。
由于不同線程中上下文對(duì)象
發(fā)表于 03-27 16:26
并發(fā)模型是用來(lái)實(shí)現(xiàn)不同應(yīng)用場(chǎng)景中并發(fā)任務(wù)的編程模型,常見(jiàn)的并發(fā)模型分為基于內(nèi)存共享的并發(fā)模型和基于消息通信的并發(fā)模型。
Actor并發(fā)
發(fā)表于 03-28 14:35
BearPi-HM_Nano開(kāi)發(fā)板鴻蒙OS內(nèi)核編程開(kāi)發(fā)——Thread多線程本示例將演示如何在BearPi-HM_Nano開(kāi)發(fā)板上使用cms
發(fā)表于 04-09 09:50
什么是 HarmonyOS?
HarmonyOS(鴻蒙操作系統(tǒng))是華為公司開(kāi)發(fā)的一款基于微內(nèi)核的分布式操作系統(tǒng)。它是一個(gè)面向物聯(lián)網(wǎng)(IoT)時(shí)代的全場(chǎng)景操作系統(tǒng),旨在為各種類型的設(shè)備提供統(tǒng)一
發(fā)表于 11-02 19:38
本文對(duì)多線程服務(wù)器的常用編程模型進(jìn)行了一個(gè)詳細(xì)的解讀,本文中的多線程服務(wù)器是運(yùn)行在 Linux 操作系統(tǒng)上網(wǎng)絡(luò)應(yīng)用程序。介紹了典型的單線程服務(wù)器編程
發(fā)表于 02-19 08:29
?7269次閱讀
爭(zhēng)議,那么鴻蒙系統(tǒng)到底是基于什么開(kāi)發(fā)的呢?下面小編就為大家?guī)?lái)鴻蒙系統(tǒng)是基于什么開(kāi)發(fā)的答案。 鴻蒙系統(tǒng)是基于什么
發(fā)表于 07-05 17:12
?1.2w次閱讀
文章目錄 5 線程編程應(yīng)用開(kāi)發(fā) 5.1 線程的使用 5.1.1 為什么要使用多線程 5.1.2 線程概念 5.1.3
發(fā)表于 12-10 19:15
?529次閱讀
CUDA 編程模型主要有三個(gè)關(guān)鍵抽象:層級(jí)的線程組,共享內(nèi)存和柵同步(barrier synchronization)。
發(fā)表于 05-19 11:32
?1890次閱讀
線程 混合協(xié)作調(diào)度模型-調(diào)度在具有相同優(yōu)先級(jí)的線程之間是協(xié)作的。 ?無(wú)需鎖 ?使代碼更簡(jiǎn)單,避免了死鎖的情況。 ?它消除了對(duì)執(zhí)行上下文/RTOS的依賴,并防止了開(kāi)銷。 ?事件在線程上下
發(fā)表于 11-02 17:07
?540次閱讀
隨著鴻蒙系統(tǒng)的不斷完善,許多應(yīng)用廠商都希望將自己的應(yīng)用移植到鴻蒙平臺(tái)上。最近,Taro 發(fā)布了 v4.0.0-beta.x 版本,支持使用 Taro 快速開(kāi)發(fā)鴻蒙原生應(yīng)用,也可將現(xiàn)有的
發(fā)表于 02-02 16:09
?876次閱讀
近日,摩爾線程與智譜AI在人工智能領(lǐng)域開(kāi)展了一輪深入的合作,共同對(duì)GPU大模型進(jìn)行了適配及性能測(cè)試。此次測(cè)試不僅涵蓋了大模型的推理能力,還涉及了基于摩爾線程夸娥(KUAE)千卡智算集群
發(fā)表于 06-14 16:40
?1079次閱讀
FA模型下的線程主要有如下三類
發(fā)表于 06-24 17:27
?435次閱讀
評(píng)論