实现不同线程间通信功能鸿蒙示例代码

本文原创发布在华为开发者社区,更多鸿蒙场景化示例请见华为开发者联盟官网"行业实践与常见问题"专题页。

介绍

本示例使用'@ohos.events.emitter'模块,实现了在同一进程不同线程间通信的能力,包括单次订阅事件、取消订阅事件,以及发送信息能力。

实现不同线程间通信功能源码链接

效果预览

使用说明

  1. 启动应用后输入框内输入要发送的信息;
  2. 点击'Send Message to B'按钮发送,下方会更新输入框内容;
  3. 点击'Unsub'按钮取消订阅,再次发送信息接收不到。

实现思路

  1. emitterSub(eventId: number, eventCallback: Callback<emitter.EventData>) 这个函数用于订阅一个特定的事件。当该事件被触发时,会调用传入的回调函数。

  2. emitterSend(eventId: number, eventParam: string)这个函数用于发送一个特定的事件,并附带一些数据。

  3. emitterShut(eventId: number)这个函数用于取消对某个事件的订阅。

typescript 复制代码
    export function emitterSub(eventId: number, eventCallback: Callback<emitter.EventData>) {
    let event: emitter.InnerEvent = {
        eventId: eventId
    }
    emitter.on(event, eventCallback)
    }

    export function emitterSend(eventId: number, eventParam: string) {
    let event: emitter.InnerEvent = {
        eventId: eventId
    }
    let eventData: emitter.EventData = {
        data: {
        param: eventParam
        }
    };
    emitter.emit(event, eventData)
    }

    export function emitterShut(eventId: number) {
    emitter.off(eventId)
    }
相关推荐
前端小D1 分钟前
JS模块化
开发语言·前端·javascript
Muen8 分钟前
iOS开发-适配XCode26、iOS26
前端
卸任33 分钟前
Electron霸屏功能总结
前端·react.js·electron
fengci.33 分钟前
ctfshow黑盒测试前半部分
前端
喵个咪44 分钟前
Headless 架构优势:内容与展示解耦,一套 API 打通全端生态
前端·后端·cms
小江的记录本1 小时前
【JEECG Boot】 JEECG Boot——数据字典管理 系统性知识体系全解析
java·前端·spring boot·后端·spring·spring cloud·mybatis
喵个咪1 小时前
传统 CMS 太笨重?试试 Headless 架构的 GoWind,轻量又强大
前端·后端·cms
chenjingming6661 小时前
jmeter导入浏览器上按F12抓的数据包
前端·chrome·jmeter
张元清1 小时前
不用 Server Components 也能做 React 流式 SSR —— 实战指南
前端·javascript·面试