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