策略模式通过接口封装可互换算法,Go中用接口+结构体组合实现;模板方法用结构体嵌入策略与钩子函数模拟固定流程;支持运行时动态装配策略与钩子,并可通过配置文件驱动策略选择。

策略模式负责行为选择
策略模式的核心是把一组可互换的算法封装成独立类型,让调用方在运行时按需切换。在 Golang 中没有接口继承,但可通过接口 + 结构体组合自然实现。
比如定义一个 OperationStrategy 接口:
type OperationStrategy interface {Execute(data interface{}) error
}
然后为不同业务场景实现具体策略:
- ValidateOnly:只校验不执行
- FullProcess:校验 + 执行 + 记录日志
- MockMode:跳过真实调用,返回模拟结果
模板方法定义流程骨架
模板方法本身不是 Go 的原生特性,但可用函数字段或嵌入结构体模拟“固定流程+可变步骤”的语义。推荐用结构体嵌入策略接口,并声明钩子方法(hook)。
立即学习“go语言免费学习笔记(深入)”;
例如定义一个 Workflow 结构体:
type Workflow struct {strategy OperationStrategy
beforeHook func() error
afterHook func(result interface{}) error
}
它提供统一的 Run 方法:
func (w *Workflow) Run(data interface{}) (interface{}, error) {if w.beforeHook != nil {
if err := w.beforeHook(); err != nil {
return nil, err
}
}
result, err := w.strategy.Execute(data)
if err != nil {
return nil, err
}
if w.afterHook != nil {
w.afterHook(result)
}
return result, nil
}
组合使用:运行时灵活装配
真正灵活的地方在于策略和模板的解耦组合。你可以在初始化时传入不同策略和钩子,无需修改流程主体。
示例:
// 使用校验策略 + 日志钩子w1 := &Workflow{
strategy: &ValidateOnly{},
beforeHook: func() error {
log.Println("开始校验流程")
return nil
},
afterHook: func(r interface{}) {
log.Printf("校验完成,结果:%v", r)
},
}
// 使用完整策略 + 监控钩子
w2 := &Workflow{
strategy: &FullProcess{},
beforeHook: recordStartTime,
afterHook: reportDuration,
}
进阶:支持配置驱动策略选择
若需从 YAML/JSON 配置文件加载策略,可定义映射关系:
var strategyMap = map[string]OperationStrategy{"validate": &ValidateOnly{},
"full": &FullProcess{},
"mock": &MockMode{},
}
再配合 viper 或 encoding/json 解析配置项,动态创建 Workflow 实例:
cfg := loadConfig()strategy := strategyMap[cfg.StrategyName]
w := &Workflow{
strategy: strategy,
beforeHook: getHook(cfg.Before),
afterHook: getHook(cfg.After),
}
这样就能做到配置即逻辑,上线无需改代码,运维可灰度切换策略。










