Napotkałem, przynajmniej w moich oczekiwaniach, dziwne zachowanie w binarnej serializacji .NET.Dziwne zachowanie serializacji binarnej .NET na Słowniku <Key, Value>
Wszystkie pozycje z Dictionary
, które zostały załadowane, są dodawane do ich rodziców po oddzwonieniu OnDeserialization
. W przeciwieństwie do tego, List
działa w drugą stronę. Może to być naprawdę denerwujące w kodzie repozytorium w świecie rzeczywistym, na przykład wtedy, gdy trzeba dodać delegatów do elementów słownika. Sprawdź przykładowy kod i obserwuj twierdzenia.
Czy to normalne zachowanie?
[Serializable]
public class Data : IDeserializationCallback
{
public List<string> List { get; set; }
public Dictionary<string, string> Dictionary { get; set; }
public Data()
{
Dictionary = new Dictionary<string, string> { { "hello", "hello" }, { "CU", "CU" } };
List = new List<string> { "hello", "CU" };
}
public static Data Load(string filename)
{
using (Stream stream = File.OpenRead(filename))
{
Data result = (Data)new BinaryFormatter().Deserialize(stream);
TestsLengthsOfDataStructures(result);
return result;
}
}
public void Save(string fileName)
{
using (Stream stream = File.Create(fileName))
{
new BinaryFormatter().Serialize(stream, this);
}
}
public void OnDeserialization(object sender)
{
TestsLengthsOfDataStructures(this);
}
private static void TestsLengthsOfDataStructures(Data data)
{
Debug.Assert(data.List.Count == 2, "List");
Debug.Assert(data.Dictionary.Count == 2, "Dictionary");
}
}
Ja trudno jest śledzić odpowiedzi ponieważ twoja instancja obiektu ma taką samą nazwę jak klasa! Jak odróżnić metody statyczne od metod członkowskich? –