尝试序列化List<Tuple<string, Type, object>>
时收到以下错误消息:没有为类型定义序列化程序:System.type
我尝试了这两种方法,只是序列化上面的集合,或者序列化一个具有定义为protoMember的相同集合的类。两者都会导致相同的错误消息。
这是不受支持的类型吗?我认为它得到了支持,我忽略了其他东西,但也许我错了?
感谢您提供任何有助于解决此问题的建议。。。
编辑:
r580 中包含对Type
序列化的支持
protobuf-net旨在序列化您的数据,而不是您的实现;Type
是一个实现细节。严格来说,添加它并不是很困难(一些特定于实现的细节实际上已经通过程序集限定的名称存储了Type
信息),但是:这不是一个关键场景,在很多方面都是而不是,我鼓励您序列化-协议缓冲区的全部意义在于,您可以在任何平台上加载数据,版本公差是一个关键特性。存储Type
信息违反了这两者。
还应该注意的是,大多数其他序列化程序(可能除了BinaryFormatter
,它已经打破了平台/版本容差的所有规则)也会拒绝序列化Type
;XmlSerializer
、DataContractSerializer
、JavaScriptSerializer
等所有都为这种情况抛出了一个异常(我刚刚检查了它们)。
此外:除非使用DynamicType
功能,否则object
的可支持性甚至更低。
以下是如何通过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; }
}