0

这应该很简单,但是在使用DataContractSerializer其中的所有自定义集合对我的业务对象进行反序列化之后,它们变成了只读的。

确切地说,我试图在反序列化后通过交换集合内的项目来操纵集合,但这会引发异常,说 Collection 是只读的。但是,在序列化之前,一切都很好。

mscorlib.dll 中出现“System.NotSupportedException”类型的未处理异常附加信息:集合是只读的。

这就是我装饰我的自定义集合类的方式。

[Serializable]
[DataContract]
[KnownType(typeof(RuleBase))]
[KnownType(typeof(RuleSet))]
public class GenericRuleCollection : ObservableCollection<IRule>
{
    //...
}

这就是我装饰我的业务对象类的方式。

[Serializable]
[DataContract]
public class RuleSet : GenericRuleContainer
{
    //...
}

[Serializable]
[DataContract(IsReference = true)]
public abstract class GenericRuleContainer : GenericRule, IRuleContainer
{        
    private GenericRuleCollection _children;     
    [DataMember]
    public GenericRuleCollection Children
    {
        get { return _children; }
        set { SetProperty(ref _children, value); }
    }
    //...
}

序列化和反序列化一段代码:

public class DataContractSerializer<T>
{
    public void SerializeToFile(string fileName, T obj)
    {
        var serializer = new DataContractSerializer(typeof(T));
        using (FileStream fs = File.Open(fileName, FileMode.Create))
        {                
            serializer.WriteObject(fs, obj);
        }
    }

    public T DeserializeFromFile(string fileName)
    {
        var serializer = new DataContractSerializer(typeof(T));
        using (FileStream fs = File.Open(fileName, FileMode.Open))
        {
            object s2 = serializer.ReadObject(fs);
            return (T)s2;
        }
    }
}
4

1 回答 1

1

好吧,在对谷歌进行了一些随机研究之后,我可以通过在我的自定义集合类上将属性装饰从[DataContract]更改为 来解决这个问题。[CollectionDataContract]

[Serializable]
[CollectionDataContract]
[KnownType(typeof(RuleBase))]
[KnownType(typeof(RuleSet))]
public class GenericRuleCollection : ObservableCollection<IRule>
{
    //...
}
于 2016-02-17T10:15:35.433 回答