HarmonyOS:使用Emitter进行线程间通信

Emitter主要提供线程间发送和处理事件的能力,包括对持续订阅事件或单次订阅事件的处理、取消订阅事件、发送事件到事件队列等。

一、Emitter的开发步骤如下:

  1. 订阅事件
复制代码
import { emitter } from '@kit.BasicServicesKit';
import { promptAction } from '@kit.ArkUI';
import { hilog } from '@kit.PerformanceAnalysisKit';

const TAG: string = 'ThreadModel';
const DOMAIN_NUMBER: number = 0xFF00;

// 定义一个eventId为1的事件
let event: emitter.InnerEvent = {
  eventId: 1
};

// 收到eventId为1的事件后执行该回调
let callback = (eventData: emitter.EventData): void => {
  promptAction.showToast({
    message: JSON.stringify(eventData)
  });
  hilog.info(DOMAIN_NUMBER, TAG, 'event callback:' + JSON.stringify(eventData));
};

// 订阅eventId为1的事件
emitter.on(event, callback);
promptAction.showToast({
  message: JSON.stringify('emitter subscribe success')
});
  1. 发送事件
复制代码
// 定义一个eventId为1的事件,事件优先级为Low
let event: emitter.InnerEvent = {
  eventId: 1,
  priority: emitter.EventPriority.LOW
};

let eventData: emitter.EventData = {
  data: {
    content: 'c',
    id: 1,
    isEmpty: false
  }
};

// 发送eventId为1的事件,事件内容为eventData
emitter.emit(event, eventData);

二、示例效果图

订阅事件


发送事件


三、示例完整代码

TestEmitter.ets

bash 复制代码
import { emitter } from '@kit.BasicServicesKit';
import { promptAction } from '@kit.ArkUI';
import { hilog } from '@kit.PerformanceAnalysisKit';

const TAG: string = 'ThreadModel';
const DOMAIN_NUMBER: number = 0xFF00;

function subEvent() {
  // 定义一个eventId为1的事件
  let event: emitter.InnerEvent = {
    eventId: 1
  };

  // 收到eventId为1的事件后执行该回调
  let callback = (eventData: emitter.EventData): void => {
    promptAction.showToast({
      message: JSON.stringify(eventData)
    });
    hilog.info(DOMAIN_NUMBER, TAG, 'event callback:' + JSON.stringify(eventData));
  };

  // 订阅eventId为1的事件
  emitter.on(event, callback);
  promptAction.showToast({
    message: JSON.stringify('emitter subscribe success')
  });
}

function sendEvent() {
  // 定义一个eventId为1的事件,事件优先级为Low
  let event: emitter.InnerEvent = {
    eventId: 1,
    priority: emitter.EventPriority.LOW
  };

  let eventData: emitter.EventData = {
    data: {
      content: 'c',
      id: 1,
      isEmpty: false
    }
  };

  // 发送eventId为1的事件,事件内容为eventData
  emitter.emit(event, eventData);
}


@Entry
@Component
struct TestEmitter {
  @State message: string = 'Hello World';
  private hadSubEvent: boolean = false;

  build() {
    Column() {
      Button('订阅事件')
        .fontColor(Color.Black)
        .fontWeight(FontWeight.Normal)
        .fontSize(16)
        .margin({ top: 20 })
        .onClick((event: ClickEvent) => {
          this.hadSubEvent = true;
          subEvent()
        })
      Button('发送事件')
        .fontColor(Color.Black)
        .fontWeight(FontWeight.Normal)
        .fontSize(16)
        .margin({ top: 20 })
        .onClick((event: ClickEvent) => {
          if (this.hadSubEvent) {
            sendEvent()
            return
          } else {
            promptAction.showToast({ message: "请点击订阅事件,再发送事件" })
          }
        })

    }
    .height('100%')
    .width('100%')
  }
}
相关推荐
猷咪7 分钟前
C++基础
开发语言·c++
IT·小灰灰9 分钟前
30行PHP,利用硅基流动API,网页客服瞬间上线
开发语言·人工智能·aigc·php
快点好好学习吧10 分钟前
phpize 依赖 php-config 获取 PHP 信息的庖丁解牛
android·开发语言·php
秦老师Q11 分钟前
php入门教程(超详细,一篇就够了!!!)
开发语言·mysql·php·db
烟锁池塘柳011 分钟前
解决Google Scholar “We‘re sorry... but your computer or network may be sending automated queries.”的问题
开发语言
是誰萆微了承諾11 分钟前
php 对接deepseek
android·开发语言·php
2601_9498683615 分钟前
Flutter for OpenHarmony 电子合同签署App实战 - 已签合同实现
java·开发语言·flutter
星火开发设计29 分钟前
类型别名 typedef:让复杂类型更简洁
开发语言·c++·学习·算法·函数·知识
qq_1777673741 分钟前
React Native鸿蒙跨平台数据使用监控应用技术,通过setInterval每5秒更新一次数据使用情况和套餐使用情况,模拟了真实应用中的数据监控场景
开发语言·前端·javascript·react native·react.js·ecmascript·harmonyos
一匹电信狗43 分钟前
【LeetCode_21】合并两个有序链表
c语言·开发语言·数据结构·c++·算法·leetcode·stl