假设字典键和值的equals和hash方法正确实现,那么测试两个字典是否相等的最简洁,最有效的方法是什么?

在这种情况下,如果两个字典包含相同的键集(顺序不重要),则称它们相等,并且对于每个这样的键,它们都同意该值。

这是我想出的一些方法(可能还有更多):

public bool Compare1<TKey, TValue>(
    Dictionary<TKey, TValue> dic1,
    Dictionary<TKey,TValue> dic2)
{
    return dic1.OrderBy(x => x.Key).
        SequenceEqual(dic2.OrderBy(x => x.Key));
}

public bool Compare2<TKey, TValue>(
    Dictionary<TKey, TValue> dic1,
    Dictionary<TKey, TValue> dic2)
{
    return (dic1.Count == dic2.Count &&
        dic1.Intersect(dic2).Count().
        Equals(dic1.Count));
}

public bool Compare3<TKey, TValue>(
    Dictionary<TKey, TValue> dic1,
    Dictionary<TKey, TValue> dic2)
{
    return (dic1.Intersect(dic2).Count().
        Equals(dic1.Union(dic2).Count()));
}

最佳答案

dic1.Count == dic2.Count && !dic1.Except(dic2).Any();

09-27 12:19