Go中原型模式需显式实现Clone()方法,通过接口定义克隆能力,手动处理浅拷贝(基本类型)或深拷贝(slice/map/指针),并可结合工厂封装原型创建逻辑。

在 Go 语言中实现原型模式,核心不是靠语言内置的“克隆”机制(Go 没有 clone 关键字或默认深拷贝),而是通过**显式定义复制逻辑**,让对象能“自己复制自己”。关键在于:每个可被原型化的类型需实现一个 Clone() 接口方法,返回该类型的独立副本。
定义 Clone 接口与基础结构
先约定统一的克隆能力:
- 定义一个 Cloner 接口,含 Clone() interface{} 方法(也可用泛型约束具体类型,但接口方式更贴近经典原型模式)
- 让需要支持原型的结构体实现该方法 —— 在方法内手动创建新实例,并逐字段赋值(浅拷贝)或递归复制(深拷贝)
- 注意:指针、切片、map、channel 等引用类型需特别处理,否则复制后仍共享底层数据
实现浅拷贝(适合不可变或值语义场景)
若结构体只含基本类型或已知安全的值类型(如 string、int、[3]int),可直接用结构体字面量构造:
- return *p(对非指针接收者)或 return &MyStruct{...}(对指针接收者)
- 例如:return &User{Name: u.Name, Age: u.Age} —— 安全、高效、清晰
实现深拷贝(应对 slice/map/指针字段)
当字段含 []string、map[string]int 或嵌套结构体指针时,必须手动分配并复制内容:
立即学习“go语言免费学习笔记(深入)”;
- 切片:用 make([]T, len(src)) + copy(dst, src) 或循环赋值
- Map:用 make(map[K]V) + 遍历复制键值对
- 嵌套结构体:调用其 Clone() 方法(若也实现了 Cloner)
- 避免用 encoding/gob 或 json 序列化反序列化 —— 性能差、不支持私有字段、有运行时开销
用工厂封装原型创建逻辑
原型模式常配合简单工厂使用,把“选哪个原型 + 克隆”封装起来:
- 定义一个 PrototypeFactory,内部维护一组注册的原型实例(如 map[string]Cloner)
- 提供 Create(name string) Cloner 方法:查表获取原型,调用其 Clone() 并返回
- 这样客户端无需知道具体类型,只需名字即可获得定制化副本
基本上就这些。Go 的原型模式不依赖语法糖,重在设计意图的落实:让对象掌握自我复制的能力,并确保副本真正独立。写清楚 Clone 方法的边界(浅 or 深)、文档说明复制行为,比追求“自动”更重要。










