鸿蒙 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
相关推荐
HwJack202 小时前
HarmonyOS APP开发中Feature模块小案例:动态化开发的“瑞士军刀“
华为·harmonyos
做个文艺程序员2 小时前
华为昇腾NPU部署开源大模型全攻略(以Qwen3-8B为例)
人工智能·深度学习·华为
鸿蒙程序媛2 小时前
【知识汇总】PixelMap 和 ArrayBuffer 详解
harmonyos
程序猿追3 小时前
HarmonyOS 6.0 网络请求深度解析:从基础调用到生产级封装
网络·华为·harmonyos
互联网散修5 小时前
鸿蒙应用开发UI基础第三十四节:媒体查询核心解析 —— 响应式布局与工具类封装
ui·harmonyos·媒体查询
性感博主在线瞎搞5 小时前
【鸿蒙开发】OpenHarmony与HarmonyOS调用C/C++教程
华为·harmonyos·鸿蒙·鸿蒙系统·openharmony
大雷神6 小时前
HarmonyOS APP<玩转React>开源教程二十三:面试题库功能
harmonyos
程序猿追7 小时前
HarmonyOS 5.0 自定义组件与状态管理实战:用 RelationalStore 构建可复用的任务看板
华为·harmonyos
程序猿追7 小时前
HarmonyOS 6.0 实战:用 Native C++ NDK 开发一款本地计步器应用
c++·华为·harmonyos