У меня есть приложение, которое сериализует данные, используя BinaryFormatter
. Член был добавлен в класс, сериализованный из одной версии в другую без изменения имени класса. Был добавлен код для обработки возможного отсутствия добавленного члена в старых сериализованных файлах:
private void readData(FileStream fs, SymmetricAlgorithm dataKey)
{
CryptoStream cs = null;
try
{
cs = new CryptoStream(fs, dataKey.CreateDecryptor(),
CryptoStreamMode.Read);
BinaryFormatter bf = new BinaryFormatter();
string string1 = (string)bf.Deserialize(cs);
// do stuff with string1
bool bool1 = (bool)bf.Deserialize(cs);
// do stuff with bool1
ushort ushort1 = (ushort)bf.Deserialize(cs);
// do stuff with ushort1
// etc. etc. ...
// this field was added later, so it may not be present
// in the serialized binary data. Check for it, and if
// it's not there, do some default behavior
NewStuffIncludedRecently newStuff = null;
try
{
newStuff = (NewStuffIncludedRecently)bf.Deserialize(cs);
}
catch
{
newStuff = null;
}
_newStuff = newStuff != null ?
new NewStuffIncludedRecently(newStuff) :
new NewStuffIncludedRecently();
}
catch (Exception e)
{
// ...
}
finally
{
// ...
}
}
Сейчас я нахожусь в том, что мне бы очень хотелось просто промыть и повторить с другим участником, которого я хотел бы добавить, что означало бы, что я бы добавил еще одно поле и блок try-catch, аналогичный тому, что для NewStuffIncludedRecently
.
Я думал просто сделать весь класс [Serializable]
, но не нарушит ли это совместимость со старыми сериализованными данными?
Меня больше всего беспокоит то, что я не понимаю, как работает десериализация. Если я добавлю обработку для другого необязательного поля, как описано выше, будет ли это работать? Какие у меня есть другие варианты, чтобы лучше справиться с этими изменениями?
Заранее спасибо как всегда.