类型注册
类型注册用于告知 Fory 如何识别并序列化你的自定义类型。对于结构体、枚举和扩展类型,注册是必需的。
为什么要注册类型?
- 类型识别:反序列化时,Fory 需要知道实际类型
- 多态支持:反序列化接口类型时,Fory 需要知道要创建哪个具体类型
- 跨语言兼容:其他语言实现需要识别并反序列化你的类型
结构体注册
通过 ID 注册
使用数值类型 ID 注册结构体,可获得更紧凑的序列化结果:
type User struct {
ID int64
Name string
}
f := fory.New()
err := f.RegisterStruct(User{}, 1)
if err != nil {
panic(err)
}
ID 使用建议:
- ID 在应用内必须唯一
- 若用于跨语言,所有语言中的 ID 必须一致
- 序列化端和反序列化端必须为同一类型使用同一 ID
通过名称注册
使用类型名字符串注册结构体。该方式更灵活,但序列化开销更高:
f := fory.New()
err := f.RegisterNamedStruct(User{}, "example.User")
if err != nil {
panic(err)
}
名称使用建议:
- 使用
namespace.TypeName约定的全限定名 - 名称在所有语言中必须唯一且一致
- 名称区分大小写
枚举注册
Go 没有原生枚举类型,但可以把整数类型按枚举注册。
通过 ID 注册
type Status int32
const (
StatusPending Status = 0
StatusActive Status = 1
StatusComplete Status = 2
)
f := fory.New()
err := f.RegisterEnum(Status(0), 1)