在我的Silverlight 4应用程序中,我通过DataContractSerializer XML-Serialization保存我的对象 - 这非常简单:
public byte[] SerializeModel(ServiceModel model)
{
System.Runtime.Serialization.DataContractSerializer serializer = new System.Runtime.Serialization.DataContractSerializer(typeof(ServiceModel));
System.IO.MemoryStream ms = new System.IO.MemoryStream();
serializer.WriteObject(ms, model);
byte[] bytes = ms.ToArray();
ms.Close();
return bytes;
}
...并通过以下方式轻松加载:
public ServiceModel DeserializeModel(string stream)
{
System.Runtime.Serialization.DataContractSerializer serializer = new System.Runtime.Serialization.DataContractSerializer(typeof(ServiceModel));
System.Xml.XmlReader reader = System.Xml.XmlReader.Create(new System.IO.StringReader(stream));
object result = serializer.ReadObject(reader);
return (ServiceModel)result;
}
(遗漏处理错误)
我的问题是,我需要使用getter和setter来保存数据(或者更好:加载)公共属性。这导致失去对数据完整性的控制。即我有一组对象,我想控制要添加或删除的对象。我需要子类化或重新实现集合,更改添加和删除方法以及我需要控制的任何其他方法。但是将其设为私有使我无法使用DataContractSerializer。
有关如何保持简单但保持对类中对象的控制的任何建议吗?
提前致谢,
弗兰克
答案 0 :(得分:2)
通常我在这些情况下做的是将我的序列化对象保持为POCO(只是获取/设置),然后一旦我反序列化它们,我将做任何我需要做的额外检查和抛出/错误处理。
所以这意味着我有用于序列化的“接口”,它只是POCO,然后一旦我反序列化它,我会进行任何一致性检查并加载/适应我的实体。在我工作的地方,我们使用我们的网络服务,我们拥有域实体和接口类。一旦我们收到请求,我们就会将其调整到我们的业务实体,然后将其传递到业务层并反转流程以获得结果。
我认为序列化是跨越一层,因此所有输入都应该经过验证,然后进行调整以保持耦合最小化。
但那只是我的0.02美元