自定义序列化器
当某个类型不是通过 [ForyObject] 生成序列化器,或者需要特殊编码方式时,应使用自定义序列化器。
实现 Serializer<T>
using Apache.Fory;
public sealed class Point
{
public int X { get; set; }
public int Y { get; set; }
}
public sealed class PointSerializer : Serializer<Point>
{
public override Point DefaultValue => new();
public override void WriteData(WriteContext context, in Point value, bool hasGenerics)
{
context.Writer.WriteVarInt32(value.X);
context.Writer.WriteVarInt32(value.Y);
}
public override Point ReadData(ReadContext context)
{
return new Point
{
X = context.Reader.ReadVarInt32(),
Y = context.Reader.ReadVarInt32(),
};
}
}
注册序列化器
Fory fory = Fory.Builder().Build();
fory.Register<Point, PointSerializer>(200);
Point value = new() { X = 10, Y = 20 };
byte[] payload = fory.Serialize(value);
Point decoded = fory.Deserialize<Point>(payload);
序列化器行为说明
WriteData/ReadData只处理载荷内容。- 除非你自行覆盖,否则引用标记和类型信息由基类
Serializer<T>.Write/Read负责处理。 DefaultValue用于空值或默认值回退路径。
最佳实践
- 保持序列化器的确定性和读写对称性。
- 对整数密集型载荷,有意识地选择 varint / fixed / tagged 编码。
- 在所有读写节点上注册自定义序列化器。
- 对普通领域模型,优先使用生成的
[ForyObject]序列化器。