本文介绍如何在不修改现有 aevent 和 bevent 类的前提下,通过观察者模式统一处理不同事件的创建逻辑,实现类型无关的事件响应机制。
在实际开发中,我们常遇到需要对多种相似但类型不同的事件(如 AEvent、BEvent)执行统一后续操作的场景。然而,受限于已有代码约束——不能修改 AEvent 和 BEvent 的原始定义——直接抽象共用接口或泛型基类不可行。此时,观察者模式(Observer Pattern)提供了一种优雅的解耦方案:它允许我们将“事件发生”与“响应行为”分离,并通过中间协调者(即观察者)聚合异构事件的状态与行为。
我们不改变 AEvent 和 BEvent 的类结构,而是为它们添加轻量级扩展能力——即支持注册外部观察者,并在关键方法(如 onAEventCreate / onBEventCreate)中主动通知观察者。这符合开闭原则(对扩展开放,对修改关闭)。
class EventObserver {
private final AEvent aEvent;
private final BEvent bEvent;
private boolean aCreated = false;
private boolean bCreated = false;
public EventObserver(AEvent aEvent, BEvent bEvent) {
this.aEvent = aEvent;
this.bEvent = bEvent;
// 注册自身为两者的观察者(需 AEvent/BEvent 提供 setObserver 方法)
aEvent.setObserver(this);
bEvent.setObserver(this);
}
// 被 AEvent 调用
public void onAEventCreated() {
this.aCreated = true;
checkAndTrigger();

}
// 被 BEvent 调用
public void onBEventCreated() {
this.bCreated = true;
checkAndTrigger();
}
private void checkAndTrigger() {
if (aCreated && bCreated) {
onBothEventsCreated();
}
}
// 统一业务入口:所有共性逻辑放在这里
protected void onBothEventsCreated() {
System.out.println("✅ Both AEvent and BEvent have been created.");
// 此处可执行日志、通知、状态更新等通用操作
}
}⚠️ 注意:此步骤是必要适配,但不改变原有方法签名与核心逻辑,仅增加观察者回调能力。
class AEvent {
private EventObserver observer;
public void setObserver(EventObserver observer) {
this.observer = observer;
}
public void onAEventCreate(A event) {
// 原有业务逻辑保持不变
System.out.println("Handling A event: " + event);
// 新增:通知观察者
if (observer != null) {
observer.onAEventCreated();
}
}
}
class BEvent {
private EventObserver observer;
public void setObserver(EventObserver observer) {
this.observer = observer;
}
public void onBEventCreate(B event) {
// 原有业务逻辑保持不变
System.out.println("Handling B event: " + event);
// 新增:通知观察者
if (observer != null) {
observer.onBEventCreated();
}
}
}public class Main {
public static void main(String[] args) {
AEvent aEvent = new AEvent();
BEvent bEvent = new BEvent();
// 构建观察者并绑定
EventObserver observer = new EventObserver(aEvent, bEvent);
// 触发事件
aEvent.onAEventCreate(new A()); // → 触发 observer.onAEventCreated()
bEvent.onBEventCreate(new B()); // → 触发 observer.onBEventCreated()
// 当二者均触发后,自动执行 onBothEventsCreated()
}
}通过上述设计,你无需泛型、反射或动态代理,即可用清晰、可控、符合设计原则的方式,将异构事件纳入统一响应管道——这正是观察者模式在真实工程中的典型价值体现。