是否有一个内置的linq方法的东西,我可以用来找出两个序列是否包含相同的项目,而不考虑订单?
例如:
{1, 2, 3} == {2, 1, 3} {1, 2, 3} != {2, 1, 3, 4} {1, 2, 3} != {1, 2, 4}
你有SequenceEquals,但是我必须首先对两个序列进行排序,不是吗?
有很多方法.假设A和B是IEnumerable.
!A.Except(B).Any() && !B.Except(A).Any() A.Count() == B.Count() && A.Intersect(B).Count() == B.Count() etc
有两个IEnumerables(A和B):
bool equal = (A.Count() == B.Count() && (!A.Except(B).Any() || !B.Except(A).Any()))
我认为这比Except(A).Count更好,因为不会评估整个Excep.只要在"除外"中找到一个元素,它就会停止.使用Count,可以评估整个Except.除此之外,我们可以避免对这些代价高昂的评估,除非首先检查Count属性.如果计数不相等,那么我们检查Excepts.