8
Class order {
Guid Id;
int qty;
}

使用 LINQ 表达式,如何验证qty列表中的所有订单是否相同?

提前致谢!

4

2 回答 2

23

您可以使用GroupBy

bool allEqual = orders.GroupBy(o => o.qty).Count() == 1;

或者,效率更高但可读性更低:

bool allEqual = !orders.GroupBy(o => o.qty).Skip(1).Any();

或者,绝对更有效地使用Enumerable.All

int firstQty = orders.First().qty;  // fyi: throws an exception on an empty sequence
bool allEqual = orders.All(o => o.qty == firstQty); 
于 2012-11-11T22:57:28.617 回答
3

如果只是为了提高可读性,我会添加一个扩展方法。

public static bool AllEqual<T>(this IEnumerable<T> source, IEqualityComparer<T> comparer = null)
{
    if (source == null)
        throw new ArgumentNullException(nameof(source));

    comparer = comparer ?? EqualityComparer<T>.Default;

    using (var enumerator = source.GetEnumerator())
    {
        if (enumerator.MoveNext())
        {
            var value = enumerator.Current;

            while (enumerator.MoveNext())
            {
                if (!comparer.Equals(enumerator.Current, value))
                    return false;
            }
        }

        return true;
    }
}

调用它:

var qtyEqual = orders.Select(order => order.qty).AllEqual();
于 2018-10-10T12:55:34.073 回答