鸿蒙:使用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);
}

以上是个人经验分享。

相关推荐
萌虎不虎3 小时前
【在鸿蒙系统中实现拍照预览功能】
华为·harmonyos
萌虎不虎4 小时前
【鸿蒙实现显示屏测试实现方法】
华为·harmonyos
用户5951433221777 小时前
HarmonyOS应用开发之滚动容器Scroll
harmonyos
用户5951433221777 小时前
HarmonyOS应用开发之瀑布流、上拉加载、无限滚动一文搞定
harmonyos
用户5951433221777 小时前
鸿蒙应用开发之@Builder自定义构建函数:值传递与引用传递与UI更新
harmonyos
不爱吃糖的程序媛9 小时前
Flutter 开发的鸿蒙AtomGit OAuth 授权应用
华为·harmonyos
xq952714 小时前
编程之路 2025年终总结 ,勇往直前 再战江湖
harmonyos
不爱吃糖的程序媛15 小时前
鸿蒙PC命令行开发 macOS 上解决 pkg-config 命令未安装的问题
macos·华为·harmonyos
二流小码农16 小时前
鸿蒙开发:自定义一个圆形动画菜单
android·ios·harmonyos
yumgpkpm17 小时前
Cloudera CDP7、CDH5、CDH6 在华为鲲鹏 ARM 麒麟KylinOS做到无缝切换平缓迁移过程
大数据·arm开发·华为·flink·spark·kafka·cloudera