工厂模式通过封装对象创建过程,提升代码可维护性与扩展性。1. 当创建逻辑复杂时,避免分散和高耦合;2. 简单工厂用函数按类型创建对象,适用于变化少的场景;3. 抽象工厂通过注册机制解耦创建逻辑,支持动态扩展;4. 实际应用中应返回接口、减少副作用,并结合配置或依赖注入提高灵活性。Go通过接口和函数式特性实现工厂模式,使创建与使用分离,业务更清晰。

在Go语言中,工厂模式是一种创建型设计模式,用于将对象的创建过程封装起来,避免直接使用构造函数暴露内部细节。通过工厂模式,可以统一管理对象的初始化逻辑,提升代码的可维护性与扩展性。
当系统中存在多种类型且创建逻辑较复杂时,直接在调用处使用结构体字面量或构造函数会导致:
工厂模式通过一个中心化函数或结构体来创建对象,屏蔽底层差异,使上层逻辑更关注行为而非实现。
简单工厂适用于类型不多、变化不频繁的场景。它通常是一个函数,接收参数并返回接口类型。
立即学习“go语言免费学习笔记(深入)”;
type Payment interface {
Pay(amount float64) string
}
type Alipay struct{}
func (a *Alipay) Pay(amount float64) string {
return fmt.Sprintf("支付宝支付 %.2f 元", amount)
}
type WechatPay struct{}
func (w *WechatPay) Pay(amount float64) string {
return fmt.Sprintf("微信支付 %.2f 元", amount)
}
// 工厂函数
func NewPayment(method string) Payment {
switch method {
case "alipay":
return &Alipay{}
case "wechat":
return &WechatPay{}
default:
panic("不支持的支付方式")
}
}
使用方式:
pay := NewPayment("alipay")
fmt.Println(pay.Pay(99.9))
这种方式简洁明了,但每新增支付方式都需修改工厂函数,违反开闭原则。
为提高扩展性,可引入抽象工厂——使用映射注册构造函数,实现无需修改代码即可扩展。
var paymentRegistry = map[string]func() Payment{}
// 注册构造函数
func RegisterPayment(name string, creator func() Payment) {
paymentRegistry[name] = creator
}
// 工厂函数
func CreatePayment(name string) Payment {
creator, exists := paymentRegistry[name]
if !exists {
panic("未知支付方式:" + name)
}
return creator()
}
初始化时注册类型:
func init() {
RegisterPayment("alipay", func() Payment { return &Alipay{} })
RegisterPayment("wechat", func() Payment { return &WechatPay{} })
}
后续新增支付方式只需在各自包中调用 RegisterPayment,无需改动工厂核心逻辑。
在实际项目中,使用工厂模式应注意以下几点:
如果对象创建涉及复杂参数或上下文,可在工厂函数中接受配置结构体,进一步提升灵活性。
基本上就这些。Go 虽无类和继承,但通过接口和函数式编程特性,依然能优雅实现工厂模式,关键是把“创建”这件事独立出来,让业务逻辑更干净。
以上就是如何在Golang中设计工厂模式管理对象创建_Golang 工厂模式对象管理实践的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号