鸿蒙 emitter 和 eventHub 的区别

在鸿蒙(HarmonyOS)开发中,EmitterEventHub是两种不同的事件通信机制,主要区别如下:


一、核心功能区别

特性 Emitter EventHub
通信范围 支持跨线程通信(如主线程与Worker线程) 仅限线程内通信(如UIAbility内组件间通信)
事件优先级 支持配置事件优先级(如IMMEDIATE、LOW) 无优先级设置
订阅类型 支持持续订阅(on)和单次订阅(once 仅支持持续订阅(on
数据约束 需封装为EventData对象,支持复杂数据类型 可传递任意类型参数(...args: Object[]

二、适用场景

  • Emitter

    • 需要跨线程通信的场景(如主线程与Worker线程交互)。
    • 需要控制事件投递优先级(如高优先级事件优先处理)。
    • 与HarmonyOS的Worker能力配合使用。
  • EventHub

    • 同线程内组件间通信(如UIAbility与Page、Page与组件)。
    • 轻量级事件传递,无需复杂配置。
    • Stage模型中通过UIAbility的context.eventHub直接获取。

三、使用方式对比

1. Emitter示例
typescript 复制代码
// 订阅事件(跨线程)
import { emitter } from '@kit.BasicServicesKit';

// 定义事件及优先级
let event: emitter.InnerEvent = { eventId: 1, priority: emitter.EventPriority.LOW };
// 订阅事件
emitter.on(event, (eventData: emitter.EventData) => {
  console.info(`Received data: ${JSON.stringify(eventData)}`);
});

// 发送事件(可在不同线程中调用)
let eventData: emitter.EventData = { data: { content: "Hello" } };
emitter.emit(event, eventData);

2. EventHub示例

typescript 复制代码
// 在UIAbility中订阅事件(同线程)
import { UIAbility } from '@kit.AbilityKit';

export default class EntryAbility extends UIAbility {
  onCreate() {
    this.context.eventHub.on('myEvent', (data: string) => {
      promptAction.showToast({ message: data });
    });
  }

  // 发送事件
  triggerEvent() {
    this.context.eventHub.emit('myEvent', 'EventHub Message');
  }
}

四、其他区别

  • 模型支持
    • EventHub仅支持Stage模型,通过context获取。
    • Emitter支持FA和Stage模型,且适用于Worker线程。
  • 资源消耗
    • Emitter因支持跨线程和优先级队列,资源占用较高。
    • EventHub更轻量,适合高频次、简单的通信场景。

总结建议

  • 跨线程通信 或需优先级控制 → 选择Emitter
  • 同线程组件解耦简单事件传递 → 使用EventHub
相关推荐
ITUnicorn7 分钟前
【HarmonyOS6】ArkTS 自定义组件封装实战:动画水杯组件
华为·harmonyos·arkts·鸿蒙·harmonyos6
小镇敲码人9 分钟前
探索华为CANN框架中的ACL仓库
c++·python·华为·acl·cann
全栈探索者33 分钟前
@Component + struct = 你的新函数组件——React 开发者的鸿蒙入门指南(第 2 期)
react·harmonyos·arkts·前端开发·deveco studio·鸿蒙next·函数组件
廖松洋(Alina)1 小时前
【收尾以及复盘】flutter开发鸿蒙APP之成就徽章页面
flutter·华为·开源·harmonyos·鸿蒙
廖松洋(Alina)2 小时前
【收尾以及复盘】flutter开发鸿蒙APP之打卡日历页面
flutter·华为·开源·harmonyos·鸿蒙
廖松洋(Alina)2 小时前
【收尾以及复盘】flutter开发鸿蒙APP之本月数据统计页面
flutter·华为·开源·harmonyos·鸿蒙
果粒蹬i2 小时前
【HarmonyOS】DAY8:React Native for OpenHarmony 实战:多端响应式布局与高可用交互设计
react native·交互·harmonyos
讯方洋哥10 小时前
HarmonyOS App开发——职前通应用App开发(下)
华为·harmonyos
摘星编程12 小时前
React Native鸿蒙版:Image图片占位符
react native·react.js·harmonyos
大雷神13 小时前
HarmonyOS智慧农业管理应用开发教程--高高种地-- 第30篇:设置与帮助系统
harmonyos