Go中组合+策略模式的核心是通过Processor接口统一处理单元,容器节点遍历子节点委托调用,策略接口ProcessingStrategy抽象可切换行为,组合体持策略字段并支持运行时注入与切换,实现行为解耦。

用 Go 实现组合 + 策略模式,核心是让一组结构相似的对象(组合)能统一调用行为,同时允许在运行时动态替换具体行为逻辑(策略),而无需修改对象结构本身。
组合结构:定义统一接口与容器
先定义一个公共接口,比如 Processor,它代表可被处理的单元。叶子节点(如单个任务)和容器节点(如任务组)都实现该接口:
- 叶子节点直接执行自身逻辑
- 容器节点遍历子节点并委托调用 Process()
这样上层代码只需面向 Processor 编程,无需区分是单个还是多个。
策略接口:抽象可切换的行为
把变化的部分抽出来,定义策略接口,例如:
立即学习“go语言免费学习笔记(深入)”;
type ProcessingStrategy interface {
Execute(data interface{}) error
}
不同策略实现不同处理方式(如日志记录、校验、加密)。组合节点不关心策略细节,只持有一个 ProcessingStrategy 字段,并在 Process() 中调用其 Execute() 方法。
组合体持有策略:运行时注入与切换
在组合结构(如 TaskGroup)中嵌入策略字段,并提供设置方法:
- 初始化时可传入默认策略
- 暴露 SetStrategy(s ProcessingStrategy) 方法供外部切换
- Process() 内部调用当前策略的 Execute(),对所有子节点生效
例如:同一组任务,测试时用 MockStrategy,上线后切为 RealDBStrategy,代码零修改。
实际使用示例:任务树 + 可插拔执行器
假设有一组任务(Task)和任务组(TaskGroup),都实现 Processor:
- TaskGroup 的 Process() 遍历 children 并逐个调用 child.Process()
- 每个 Process 调用当前绑定的 strategy.Execute(data)
- 外部可通过 group.SetStrategy(&AuditStrategy{}) 全局开启审计
策略切换不影响组合结构,也不需要重新构造对象树 —— 行为解耦彻底。










