中介者模式在Go中通过接口定义协调能力,同事对象仅依赖中介者接口并注入实现,所有交互经中介者转发,其内部管理状态与分发逻辑,强调职责分离、松耦合与可测试性。
中介者模式通过引入一个中介对象来封装一系列对象之间的交互,让对象之间不再相互引用,而是通过中介者进行通信。在 Go 语言中,由于没有类继承和接口强制实现的强约束,该模式更侧重于职责分离与松耦合设计,而非严格遵循传统 OOP 实现。
用 interface 明确中介者应提供的协调能力,比如转发消息、触发事件、同步状态等。这能让同事对象(Colleague)只依赖抽象,不依赖具体实现。
每个参与协作的结构体(如 User、ChatRoom、NotificationService)仅保存一个中介者接口字段,初始化时注入,不自行创建或查找其他同事。
中介者结构体负责维护同事注册信息(如用户列表、房间映射)、校验权限、转换消息格式、控制广播范围等。它知道“谁在哪儿”“谁能做什么”,但同事对此一无所知。
合 channel 或 callback 实现异步通知,避免阻塞发送方Go 中没有多重继承,但可通过嵌入(embedding)+ 接口组合灵活复用行为。例如,一个 BaseColleague 类型可嵌入通用字段(ID、Mediator)和基础方法(SendToMediator),再被具体类型匿名嵌入。
不复杂但容易忽略的是:中介者本身不该成为新瓶颈或状态黑洞。保持它轻量、专注协调,把业务规则下沉到领域对象或服务层,才能真正降低耦合,提升系统可维护性。