鸿蒙:使用worker实现多线程通信

前言:

我们还是老样子,跟着官方文档学习与实践,链接如下:

https://developer.huawei.com/consumer/cn/doc/harmonyos-guides/worker-introduction#worker%E8%BF%90%E4%BD%9C%E6%9C%BA%E5%88%B6https://developer.huawei.com/consumer/cn/doc/harmonyos-guides/worker-introduction#worker%E8%BF%90%E4%BD%9C%E6%9C%BA%E5%88%B6看了文档,我们就来练一练,本人的练习效果图和代码如下:

代码如下:

1、Index.ets

复制代码
import { init, postMessage, onMessage } from '../workers/WorkerUtil';

@Entry
@Component
struct Index {
  @State message: string = '使用worker发送消息';

  build() {
    Column({ space: 30 }) {
      Text("使用worker触发弹窗")
        .fontSize(30)
        .fontWeight(FontWeight.Bold)

        .onClick(() => {
          init(this.getUIContext())
          onMessage()
          postMessage("展示弹窗")
        })
      Text(this.message)
        .fontSize(30)
        .fontWeight(FontWeight.Bold)

        .onClick(() => {
          onMessage()
          postMessage(" 番茄")
          postMessage(" 鼠标")
          postMessage(" 键盘")
          postMessage(" 数据线")
        })
    }
    .justifyContent(FlexAlign.Center)
    .height('100%')
    .width('100%')
  }
}

2、WorkUtil.ets

复制代码
import { MessageEvents, worker } from "@kit.ArkTS";

// 创建Worker对象
let workerInstance = new worker.ThreadWorker('entry/ets/workers/worker.ets');

export let UIContextInstance: UIContext | undefined

export function init(uiContext: UIContext) {
  // 获取UIContext对象
  UIContextInstance = uiContext;
}

export function onMessage() {
  // 注册onmessage回调,捕获宿主线程接收到来自其创建的Worker通过workerPort.postMessage接口发送的消息。该回调在宿主线程执行
  workerInstance.onmessage = (e: MessageEvents) => {
    let data: string = e.data;
    console.info('workerInstance onmessage is: ', data);
    if (UIContextInstance && data == "使用worker发送消息展示弹窗") {
      UIContextInstance.showAlertDialog({ message: data })
    }
  }
}

export function postMessage(data: string) {
  // 发送消息给Worker线程
  workerInstance.postMessage(data);
}

3、worker.ets

复制代码
// worker.ets
import { ErrorEvent, MessageEvents, ThreadWorkerGlobalScope, worker } from '@kit.ArkTS';

const workerPort: ThreadWorkerGlobalScope = worker.workerPort;

// 注册onmessage回调,当Worker线程收到来自其宿主线程通过postMessage接口发送的消息时被调用,在Worker线程执行
workerPort.onmessage = (e: MessageEvents) => {
  let data: string = e.data;
  console.info('workerPort onmessage is: ', data);
  // 向宿主线程发送消息
  workerPort.postMessage('使用worker发送消息' + data);
}

// 注册onmessageerror回调,当Worker对象接收到一条无法被序列化的消息时被调用,在Worker线程执行
workerPort.onmessageerror = () => {
  console.error('workerPort onmessageerror');
}

// 注册onerror回调,捕获Worker在执行过程中发生的异常,在Worker线程执行
workerPort.onerror = (err: ErrorEvent) => {
  console.error('workerPort onerror err is: ', err.message);
}

以上是个人经验分享。

相关推荐
君逸臣劳2 小时前
【Harmony Next】手把手撸一个支持高度自定义的Toast
harmonyos
安卓开发者3 小时前
鸿蒙NEXT传感器开发概述:开启智能感知新时代
华为·harmonyos
nju_spy14 小时前
华为AI岗 -- 笔试(一)
人工智能·深度学习·机器学习·华为·笔试·dbscan·掩码多头自注意力
安卓开发者16 小时前
鸿蒙NEXT按键拦截与监听开发指南
华为·harmonyos
2503_9284115617 小时前
10.13 Tabs选项卡布局
华为·harmonyos·鸿蒙
我爱学习_zwj18 小时前
【鸿蒙进阶-7】鸿蒙与web混合开发
前端·华为·harmonyos
HMSCore21 小时前
消息推送策略:如何在营销与用户体验间找到最佳平衡点
harmonyos
HMSCore21 小时前
同一设备多账号登录,如何避免消息推送“串门”?
harmonyos
零點壹度ideality1 天前
鸿蒙实现可以上下左右滑动的表格-摆脱大量ListScroller
前端·harmonyos
●VON1 天前
重生之我在大学自学鸿蒙开发第七天-《AI语音朗读》
学习·华为·云原生·架构·harmonyos