以下是一个使用上下文来传递参数的策略模式的例子,这个例子中,我们将创建两种不同的支付策略,它们需要不同的参数:
代码语言:javascript复制package main
import "fmt"
// Strategy Interface
type PaymentStrategy interface {
Pay(ctx *PaymentContext) string
}
// Concrete Strategy
type PayPalStrategy struct{}
func (p *PayPalStrategy) Pay(ctx *PaymentContext) string {
return fmt.Sprintf("Paid %d using PayPal. PayPal user: %s", ctx.Amount, ctx.PayPalUser)
}
// Concrete Strategy
type CreditCardStrategy struct{}
func (c *CreditCardStrategy) Pay(ctx *PaymentContext) string {
return fmt.Sprintf("Paid %d using Credit Card. Card Number: %s", ctx.Amount, ctx.CreditCardNumber)
}
// Context
type ShoppingCart struct {
ctx *PaymentContext
}
func (s *ShoppingCart) checkout() string {
return s.ctx.Strategy.Pay(s.ctx)
}
// PaymentContext serves as the context for payment strategies
type PaymentContext struct {
Strategy PaymentStrategy
Amount int
PayPalUser string
CreditCardNumber string
}
func main() {
ctx := &PaymentContext{Strategy: &PayPalStrategy{}, Amount: 200, PayPalUser: "user@example.com"}
cart := &ShoppingCart{ctx: ctx}
fmt.Println(cart.checkout()) // Paid 200 using PayPal. PayPal user: user@example.com
ctx = &PaymentContext{Strategy: &CreditCardStrategy{}, Amount: 300, CreditCardNumber: "1234-5678-9012-3456"}
cart = &ShoppingCart{ctx: ctx}
fmt.Println(cart.checkout()) // Paid 300 using Credit Card. Card Number: 1234-5678-9012-3456
}
在这个例子中,我们创建了一个新的 PaymentContext 结构,它既包含了支付策略,又包含了支付所需的所有参数。我们的 ShoppingCart 仍然只需要一个 PaymentContext 对象,但是现在 PaymentContext 可以包含任何支付策略需要的参数。
注意,这只是一种可能的解决方案,具体的解决方案取决于你的应用场景和需求。在一些情况下,可能需要采用其他的方法来处理不同策略需要不同参数的问题。