鸿蒙 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
相关推荐
坚果派·白晓明23 分钟前
【鸿蒙PC三方库移植适配框架解读系列】第五篇:完整流程图与角色职责
c语言·c++·华为·harmonyos·鸿蒙
号码认证服务1 小时前
如何让经销商接电话时看到“XX集团”?申请号码认证统一上线
服务器·经验分享·sql·华为·智能手机·华为云·云计算
shaodong11233 小时前
HarmonyOS NEXT 数据持久化三剑客:Preferences、RelationalStore 与 KVDB 选型实战
华为·harmonyos
richard_yuu3 小时前
鸿蒙从零搭建参赛项目|心晴驿站:开发环境配置、技术选型与项目规范落地
华为·harmonyos
shaodong11233 小时前
鸿蒙自定义弹窗(CustomDialog)的 8 种封装姿势
华为·harmonyos
xmdy58665 小时前
Flutter + 开源鸿蒙跨端实战|基于空间地理信息的**城市全域智慧泊车调度与多维运维管理平台** Day1 项目架构基座与工程化环境搭建
flutter·开源·harmonyos
枫叶丹46 小时前
【HarmonyOS 6.0】状态栏扩展新特性:点击状态栏图标展开二级菜单的场景动效详解
开发语言·华为·harmonyos
想你依然心痛7 小时前
HarmonyOS 6(API 23)实战:基于悬浮导航、沉浸光感与Face AR & Body AR的“灵犀筑境“——PC端沉浸式AR建筑空间评审系统
华为·ar·harmonyos·悬浮导航·沉浸光感
xmdy58667 小时前
Flutter+开源鸿蒙全域智慧泊车调度管理平台 Day4 订单全流程闭环+支付核验+会员权益+个人中心开发
flutter·开源·harmonyos
前端不太难7 小时前
鸿蒙 App 多端 UI 不一致的原因
ui·状态模式·harmonyos