12

尝试序列化时收到以下错误消息List<Tuple<string, Type, object>>:No Serializer defined for type: System.Type

我都试过了,只是序列化上面的集合或序列化一个与protoMember定义相同的集合的类。两者都会导致相同的错误消息。

这是不受支持的类型吗?我认为它是受支持的,但我忽略了其他一些东西,但也许我不正确?

感谢您提供任何可能有助于解决此问题的指示...

4

1 回答 1

15

编辑:

Typer580 中包含对序列化的支持


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; }
}
于 2012-09-18T11:10:08.953 回答