Class order {
Guid Id;
int qty;
}
使用 LINQ 表达式,如何验证qty
列表中的所有订单是否相同?
提前致谢!
您可以使用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);
如果只是为了提高可读性,我会添加一个扩展方法。
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();