自定义序列化器
当某个类型不是通过 [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]生成的序列化器。