EventBus

发布: (2026年1月9日 GMT+8 15:43)
2 min read
原文: Dev.to

Source: Dev.to

SimpleEventBus 实现

import java.util.List;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.CopyOnWriteArrayList;

// Concrete EventBus implementation
public class SimpleEventBus implements MyEventBus {

    private final ConcurrentHashMap>> listenersMap = new ConcurrentHashMap<>();

    // Publish an event to all listeners of a source
    public void push(String source, T event) {
        List> listeners = listenersMap.get(source);
        if (listeners != null && !listeners.isEmpty()) {
            for (MyEventListener listener : listeners) {
                try {
                    listener.onEvent(source, event);
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        }
    }

    // Get number of subscribers for a source
    public int getSubscriberCount(String source) {
        List> listeners = listenersMap.get(source);
        return (listeners == null) ? 0 : listeners.size();
    }

    @Override
    public void subscribe(String source, MyEventListener listener) {
        listenersMap.computeIfAbsent(source, key -> new CopyOnWriteArrayList<>()).add(listener);
    }

    @Override
    public void unsubscribe(String source, MyEventListener listener) {
        listenersMap.computeIfPresent(source, (key, list) -> {
            list.remove(listener);
            return list.isEmpty() ? null : list;
        });
    }
}

使用示例

上面的 EventBus 是一个类似 Guava 的 EventBus 实现。无需额外说明。

class MessageListener implements MyEventListener {
    private final String name;

    public MessageListener(String name) { this.name = name; }

    @Override
    public void onEvent(String source, Message event) {
        System.out.println(name + " received from [" + source + "]: " + event.getText());
    }
}
Back to Blog

相关文章

阅读更多 »

介绍 Go 的 Rate Limiter 库

概述 在现代后端系统中,速率限制(rate limiting)是必不可少的。如果没有它,API 将面临滥用、资源耗尽和不公平使用的风险。该库提供…

Java 多线程/并发

什么是 Java 中的多线程?Java 中的多线程是一项功能,允许程序的两个或多个部分(称为 thread)并发执行,……