如何使以下方法更具功能性?linq-style?
public static Dictionary<T, T> MergeDict<T, T>(Dictionary<T, T> a, Dictionary<T, T> b)
{
var e = new Dictionary<T, T>();
a.Concat(b).ToList().ForEach(pair =>
{
e[pair.Key] = pair.Value;
});
return e;
}
答案 0 :(得分:10)
要继续使用重复的丢弃方式,只需分组并获取组中的获胜项目(例如最后一项)。
first.Concat(second)
.GroupBy(kvp => kvp.Key, kvp => kvp.Value)
.ToDictionary(g => g.Key, g => g.Last());
答案 1 :(得分:3)
您可以直接使用ToDictionary:
public static Dictionary<T, T> MergeDict<T, T>(Dictionary<T, T> a, Dictionary<T, T> b)
{
return a.Concat(b).ToDictionary(kvp => kvp.Key, kvp => kvp.Value);
}
请注意,这会在重复键的情况下引发异常。
如果您需要处理重复的密钥,您需要决定如何处理这些密钥。例如,这将删除“b”中的重复项:
public static Dictionary<T, T> MergeDict<T, T>(Dictionary<T, T> a, Dictionary<T, T> b)
{
return a.Concat(b.Where(kvp => !a.ContainsKey(kvp.Key)).ToDictionary(kvp => kvp.Key, kvp => kvp.Value);
}
要获得与原始行为相同的行为,您可以采用另一种方式(将KeyValuePair值保持为“b”):
public static Dictionary<T, T> MergeDict<T, T>(Dictionary<T, T> a, Dictionary<T, T> b)
{
return b.Concat(a.Where(kvp => !b.ContainsKey(kvp.Key)).ToDictionary(kvp => kvp.Key, kvp => kvp.Value);
}
答案 2 :(得分:0)
也许就是这样。
public static IDictionary<T, U> Merge<T, U>(this IDictionary<T, U> first, IDictionary<T, U> second)
{
return first.Concat(second).ToDictionary(kvp => kvp.Key, kvp => kvp.Value);
}