策略模式通过接口定义算法行为,实现多种策略结构体并由上下文动态切换。定义PaymentStrategy接口及CreditCard、PayPal等具体策略,通过PaymentContext设置和执行策略,支持运行时根据用户类型等条件灵活更换支付方式,提升解耦与可扩展性。

在Golang中实现策略模式,核心是通过接口定义算法行为,并让不同策略实现该接口。运行时根据需要动态切换具体算法,从而实现解耦和灵活扩展。
定义策略接口
先定义一个统一的接口,描述算法的公共方法。比如处理数据的策略:
type PaymentStrategy interface {
Pay(amount float64) string
}
实现多种具体策略
创建多个结构体实现同一接口,每个代表一种算法或行为。
type CreditCardStrategy struct {
Name string
}
func (c *CreditCardStrategy) Pay(amount float64) string {
return fmt.Sprintf("Paid %.2f using Credit Card by %s", amount, c.Name)
}
type PayPalStrategy struct {
Email string
}
func (p *PayPalStrategy) Pay(amount float64) string {
return fmt.Sprintf("Paid %.2f using PayPal account %s", amount, p.Email)
}
上下文管理策略切换
使用一个上下文结构体持有策略接口,允许运行时设置和调用不同策略。
立即学习“go语言免费学习笔记(深入)”;
type PaymentContext struct {
strategy PaymentStrategy
}
func (p *PaymentContext) SetStrategy(s PaymentStrategy) {
p.strategy = s
}
func (p *PaymentContext) ExecutePayment(amount float64) string {
if p.strategy == nil {
return "No strategy set"
}
return p.strategy.Pay(amount)
}
这样可以在程序运行中随时更换算法:
context := &PaymentContext{}
// 使用信用卡支付
context.SetStrategy(&CreditCardStrategy{Name: "Alice"})
fmt.Println(context.ExecutePayment(100.0))
// 切换为PayPal支付
context.SetStrategy(&PayPalStrategy{Email: "alice@example.com"})
fmt.Println(context.ExecutePayment(80.0))
支持配置化或条件驱动的策略选择
可以结合配置、用户输入或业务规则决定使用哪个策略。
func GetStrategyByUserType(userType string) PaymentStrategy {
switch userType {
case "premium":
return &CreditCardStrategy{Name: "VIP User"}
case "basic":
return &PayPalStrategy{Email: "user@example.com"}
default:
return &CreditCardStrategy{Name: "Guest"}
}
}
然后动态注入:
strategy := GetStrategyByUserType("basic")
context.SetStrategy(strategy)
基本上就这些。通过接口抽象 + 运行时赋值,Golang能很简洁地实现策略模式,无需复杂框架。关键是把变化的算法封装成独立类型,统一通过接口调用,提升代码可维护性和测试便利性。










