鸿蒙多线程开发——同步任务处理

鸿蒙多线程同步任务处理方式

1、概 述

目前,多线程的开发我们已经学过TaskPool和Worker两种方式:

我们现在讨论下多线程的同步任务处理。

同步任务是指在多个线程之间协调执行的任务,其目的是确保多个任务按照一定的顺序和规则执行,例如使用锁来防止数据竞争。

由于TaskPool偏向于单个独立的任务,因此当各个同步任务之间相对独立时推荐使用TaskPool,例如一系列导入的静态方法,或者单例实现的方法。如果同步任务之间有关联性,则需要使用Worker,例如无法单例创建的类对象实现的方法。

2、Worker处理关联的同步任务

当一系列同步任务需要使用同一个句柄调度,或者需要依赖某个统一调度管理的类,而这些类或者句柄无法在不同任务池之间共享时,我们需要使用Worker。

👉🏻 step 1

 在主线程中创建Worker对象,同时接收Worker线程发送回来的消息,根据实际的业务场景,再发送对应的指令到worker中。

// Index.etsimport { worker } from '@kit.ArkTS';@Entry@Componentstruct Index {
  
    @State message: string = 'Hello World';  build() {
  
  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值