Go中组合+策略模式的核心是通过Processor接口统一处理单元,容器节点遍历子节点委托调用,策略接口ProcessingStrategy抽象可切换行为,组合体持策略字段并支持运行时注入与切换,实现行为解耦。
用 Go 实现组合 + 策略模式,核心是让一组结构相似的对象(组合)能统一调用行为,同时允许在运行时动态替换具体行为逻辑(策略),而无需修改对象结构本身。
先定义一个公共接口,比如 Processor,它代表可被处理的单元。叶子节点(如单个任务)和容器节点(如任务组)都实现该接口:
这样上层代码只需面向 Processor 编程,无需区分是单个还是多个。
把变化的部分抽出来,定义策略接口,例如:
type ProcessingStrategy interface {
Execute(data interface{}) error
}
不同策略实现不同处理方式(如日志记录、校验、加密)。组合节点不关心策略细节,只持有一个 ProcessingStrategy 字段,并在 Proc
ess() 中调用其 Execute() 方法。
在组合结构(如 TaskGroup)中嵌入策略字段,并提供设置方法:
例如:同一组任务,测试时用 MockStrategy,上线后切为 RealDBStrategy,代码零修改。
假设有一组任务(Task)和任务组(TaskGroup),都实现 Processor:
策略切换不影响组合结构,也不需要重新构造对象树 —— 行为解耦彻底。