我有一些使用 Protobuf.net 的相当简单的代码,它抛出了一个非常奇怪的异常。在第 167 行的 MetaType.cs 中,它会抛出 InvalidOperationException “一旦生成了序列化程序,就无法更改类型”。这是什么意思,我该如何解决?
我的代码如下所示:
此方法启动所有序列化:
while (!Parallel.For(0, 100, (i) =>
{
Widget w;
lock (f) { w = f.CreateWidget(); }
SerialiseWidget(w);
}).IsCompleted)
{
Thread.Sleep(10);
}
非常简单,它只是并行循环遍历所有内容,并序列化 100 个小部件。
serialise 方法也很简单:
private byte[] SerialiseWidget(Widget w)
{
using (MemoryStream m = new MemoryStream())
{
Serializer.Serialize<PacketChunk>(m, w);
return m.ToArray();
}
}
最后,小部件类如下所示:
[ProtoContract]
private class Widget
{
[ProtoMember(1)]
public int a;
[ProtoMember(2)]
public byte[] b;
[ProtoMember(3)]
public Thing c; //Thing is itself a protocontract
[ProtoMember(4)]
public int d;
[ProtoMember(5)]
public int e;
}
编辑:: 我怀疑这可能与我并行循环的事实有关。Protobuf.net 对于这种事情的线程安全性如何?