使用DataContract集合进行反序列化<;类>;到派生类
本文关键字:DataContract gt 派生 集合 lt 反序列化 使用 | 更新日期: 2023-09-27 17:57:33
标题有点令人困惑,希望有人知道它更适合我的问题。
我正在尝试创建一个从Collection<Classname>
派生的类,以实现保存和加载配置文件的简单方法。写入文件没有问题,但我无法实现deserialze函数。我不确定如何将反序列化的内容分配回我的实例。
当前方法:
[DataContract(Name = "Configurations", Namespace = "")]
public class Configurations : Collection<Configuration>
{
internal void SerializeToBinaryFile(string path)
{
Helper.DumpObjectToBinaryFile(this, path);
}
internal void DeserializeFromBinaryFile(string path)
{
// Getting Error:
// This expression can not be used as an assignment target
this = Helper.GetObjectFromBinaryFile<Collection<Configuration>>(path);
}
}
我熟悉this.Add([Configuration])
,但这只是给了我插入一个项目的机会。我曾考虑过使用foreach(Configuration c in temporaryObject
并逐个添加它们,但这不是最好的解决方案。
谢谢你的提示!
编辑1:
我添加了foreach迭代,用于添加配置
internal void DeserializeFromBinaryFile(string path)
{
foreach (var c in Helper.GetObjectFromBinaryFile<Collection<Configuration>>(path))
{
Add(c);
}
}
这似乎很有效。有人知道更好的模式吗?
无论您是在进行反序列化还是其他操作,都不能将类的新实例分配给"this"。下面的代码只使用了新的构造函数,也不起作用。基本上,在这一点上,内存中确实有两个不同的类实例。
public class Point
{
public int X { get; set; }
public int Y { get; set; }
public void CreatePoint(int x, int y)
{
// Doesn't work either
this = new Point();
}
}
您必须在类的主体之外执行此操作,因此,请使用静态反序列化方法:
[DataContract(Name = "Configurations", Namespace = "")]
public class Configurations : Collection<Configuration>
{
internal void SerializeToBinaryFile(string path)
{
Helper.DumpObjectToBinaryFile(this, path);
}
internal static Configurations DeserializeFromBinaryFile(string path)
{
return Helper.GetObjectFromBinaryFile<Collection<Configuration>>(path);
}
}