我创建了一个可序列化的测试对象:
[Serializable]
public class TestObject : ISerializable
{
public string FirstName;
public TestObject()
{
}
public TestObject(SerializationInfo info, StreamingContext context)
{
FirstName = info.GetString("firstName");
}
public void GetObjectData(SerializationInfo info, StreamingContext context)
{
info.AddValue("firstName", FirstName);
}
}然后将其序列化:
var test = new TestObject { FirstName = "John" };
using (var stream = new FileStream(@"c:\temp\test.dat", FileMode.Create, FileAccess.Write))
{
var formatter = new BinaryFormatter();
formatter.Serialize(stream, test);
}我更改了类,使其具有一个OptionalFied,并尝试反序列化旧的序列化对象:
[Serializable]
public class TestObject : ISerializable
{
public string FirstName;
[OptionalField]
public string SecondName;
public TestObject()
{
}
public TestObject(SerializationInfo info, StreamingContext context)
{
FirstName = info.GetString("firstName");
SecondName = info.GetString("secondName");
}
public void GetObjectData(SerializationInfo info, StreamingContext context)
{
info.AddValue("firstName", FirstName);
}当我将构造函数更改为读取新的可选字段时,会在"SecondName =info.GetString(“secondName”);“处引发异常:
using (var stream = new FileStream(@"c:\temp\test1.dat", FileMode.Open, FileAccess.Read))
{
var formatter = new BinaryFormatter();
var myInstance = (TestObject)formatter.Deserialize(stream);
}当您实现OptionalFieldAttribute时,是否真的不支持ISerializable?
发布于 2015-07-23 16:57:02
对于旧的序列化对象,不会有第二个名称字段,因此它的SerializationEntry就不存在了。
在访问该值之前,需要检查该项是否存在:
foreach (SerializationEntry entry in info)
{
switch (entry.Name)
{
case "firstname":
Firstname = (string)entry.Value;
break;
case "secondname":
Secondname = (string)entry.Value;
break;
}
}https://stackoverflow.com/questions/31593471
复制相似问题