![](/img/trans.png)
[英]Making a reusable predicate for EntitySet<T>, IQueryable<T> and IEnumerable<T>
[英]IEnumerable<T>.Contains with predicate
我只需要澄清給定的集合包含一個元素。
我可以通過collection.Count(foo => foo.Bar == "Bar") > 0)
來做到這一點,但它會做不必要的工作 - 迭代整個集合,而我需要在第一次出現時停止。
但我想嘗試將Contains()
與謂詞一起使用,例如foo => foo.Bar == "Bar"
。
目前IEnumerable<T>.Contains
有兩個簽名:
IEnumerable<T>.Contains(T)
IEnumerable<T>.Contains(T, IEqualityComparer<T>)
所以我必須指定一些變量來檢查:
var collection = new List<Foo>() { foo, bar };
collection.Contains(foo);
或編寫我的自定義IEqualityComparer<Foo>
,它將用於我的收藏:
class FooComparer : IEqualityComparer<Foo>
{
public bool Equals(Foo f1, Foo f2)
{
return (f1.Bar == f2.Bar); // my predicate
}
public int GetHashCode(Foo f)
{
return f.GetHashCode();
}
}
那么有沒有其他方法可以使用謂詞?
.Any(predicate)
聽起來像你想要的; 返回bool
,一找到匹配就返回true
,否則返回false
。 還有:
.All(predicate)
其行為方式類似,一旦找到不匹配就返回false
,否則為true
。
您可以使用Any(predicate)
。 它將返回true或false,具體取決於謂詞是否存在於某個集合中。
看一下IEnumerable<T>.Any
擴展。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.