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

以上是个人经验分享。

相关推荐
C雨后彩虹8 小时前
任务最优调度
java·数据结构·算法·华为·面试
盐焗西兰花11 小时前
鸿蒙学习实战之路-蓝牙设置完全指南
学习·华为·harmonyos
Van_Moonlight12 小时前
RN for OpenHarmony 实战 TodoList 项目:加载状态 Loading
javascript·开源·harmonyos
Van_captain14 小时前
rn_for_openharmony常用组件_Divider分割线
javascript·开源·harmonyos
cn_mengbei15 小时前
鸿蒙PC原生应用开发实战:ArkTS与DevEco Studio从零构建跨端桌面应用全栈指南
华为·wpf·harmonyos
前端不太难17 小时前
从本地到多端:HarmonyOS 分布式数据管理实战详解
分布式·状态模式·harmonyos
Yeats_Liao17 小时前
MindSpore开发之路(二十五):融入开源:如何为MindSpore社区贡献力量
人工智能·分布式·深度学习·机器学习·华为·开源
行者9618 小时前
Flutter适配OpenHarmony:国际化i18n实现中的常见陷阱与解决方案
开发语言·javascript·flutter·harmonyos·鸿蒙
weisian15118 小时前
入门篇--知名企业-26-华为-2--华为VS阿里:两种科技路径的较量与共生
人工智能·科技·华为·阿里
cn_mengbei19 小时前
鸿蒙PC开发实战:Qt环境搭建保姆级教程与常见问题避坑指南(HarmonyOS 4.0+DevEco Studio 3.1最新版)
qt·华为·harmonyos