Estoy probando el método UNION para fusionarme a diccionarios (de tipo Diccionario). Funciona bien con TValue type es string o int o incluso object. Pero si el tipo de TValue es una colección (probado con List y object []) se lanza una excepción: "ArgumentException: ya se ha agregado un elemento con la misma clave".Merge Dictionary <TKey, TValue> con el método Enumerable.Union
Aquí está mi código:
Dictionary<int,string> _dico1 = new Dictionary<int, string>()
{
{0, "zero"},
{1, "one"}
};
Dictionary<int,string> _dico2 = new Dictionary<int,string>()
{
{1 , "one"},
{2 , "two"},
{3 , "three"},
{4 , "four"},
{5 , "five"},
{6 , "six"}
};
Dictionary<int, List<string>> _dico3 = new Dictionary<int, List<string>>()
{
{0, new List<string>{"zero"}},
{1, new List<string>{"one"}}
};
Dictionary<int, List<string>> _dico4 = new Dictionary<int, List<string>>()
{
{1, new List<string>{"one"}},
{2, new List<string>{"two"}},
{3, new List<string>{"three"}},
{4, new List<string>{"four"}},
{5, new List<string>{"five"}},
{6, new List<string>{"six"}},
};
// works fine
var mergeDico = _dico1.Union(_dico2).ToDictionary(key => key.Key, value => value.Value);
// throw an ArgumentException : An item with the same key has already been added
var mergeDico2 = _dico3.Union(_dico4).ToDictionary(key => key.Key, value => value.Value);
Por qué el comportamiento no es lo mismo? ¿Y cómo resolver este problema?
¡Gracias!
Así, en el primer caso, funciona porque el tipo TValue son los tipos de valor (int) o tipo inmutable (cadena) y, en el segundo caso, falla porque TValue es tipo de referencia? – Florian
@Florian: No se debe directamente a la inmutabilidad, se debe a si los tipos implicados tienen semántica de igualdad de valores. Aún puede tener tipos inmutables que no hacen eso. –