我在尝试序列化 List<Tuple<string, Type, object>>
时收到以下错误消息: 没有为类型定义序列化器:System.Type
我都试过了,只是序列化上述集合或序列化一个类,该类具有定义为 protoMember 的相同集合。两者都会导致相同的错误消息。
这是不受支持的类型吗?我认为它是受支持的,但我忽略了其他一些东西,但也许我不正确?
感谢任何可能有助于解决此问题的指示...
最佳答案
编辑:
r580 中包含对 Type
序列化的支持
protobuf-net 旨在序列化您的数据,而不是您的实现; Type
是一个实现细节。严格来说,添加起来并不难(一些特定于实现的细节实际上已经通过程序集限定名称最终存储了 Type
信息),但是:它不是一个关键场景,并且在很多方面不是我鼓励你序列化的东西 - protocol buffers 的全部要点是你可以在任何平台上加载数据,版本容错是一个关键特性。存储 Type
信息违反了这两个条件。
还应该注意的是,大多数其他序列化程序(也许 BinaryFormatter
除外,它已经打破了平台/版本容错的每条规则)将也拒绝序列化类型
; XmlSerializer
、DataContractSerializer
、JavaScriptSerializer
等 all 为这种情况抛出异常(我刚刚检查了它们)。
此外:object
甚至更难 受支持,除非您使用 DynamicType
功能。
下面是如何通过 Type
的代理来完成的:
using ProtoBuf;
using ProtoBuf.Meta;
using System;
using System.Runtime.Serialization;
static class Program
{
public static void Main(string[] args)
{
// register a surrogate for Type
RuntimeTypeModel.Default.Add(typeof(Type), false)
.SetSurrogate(typeof(TypeSurrogate));
// test it
var clone = Serializer.DeepClone(new Foo { Type = typeof(string) });
}
}
[ProtoContract]
class TypeSurrogate
{
[ProtoMember(1)]
public string AssemblyQualifiedName { get; set; }
// protobuf-net wants an implicit or explicit operator between the types
public static implicit operator Type(TypeSurrogate value)
{
return value==null ? null : Type.GetType(value.AssemblyQualifiedName);
}
public static implicit operator TypeSurrogate(Type value)
{
return value == null ? null : new TypeSurrogate {
AssemblyQualifiedName = value.AssemblyQualifiedName };
}
}
[DataContract]
public class Foo
{
[DataMember(Order=1)]
public Type Type { get; set; }
}
关于c# - Protobuf-Net 错误消息 : No Serializer defined for type: System. 类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12475521/