开发者

LINQ results when there are no matches?

What exactly does a LINQ function return when there are no matches? Take the Where method, for example:

var numbers = Enumerable.Range(1, 10);
var results = numbers.Where(n 开发者_StackOverflow=> n == 50);

What would be in results at this point?


results itself is just a query. Until you start to iterate through it (either explicitly or via a call like Count()), nothing has checked whether there are any results or not. It's only when you enumerate it that anything will happen.

So you could do:

foreach (int x in results)
{
    Console.WriteLine("This won't happen");
}

Or:

Console.WriteLine(results.Any()); // Will print false
Console.WriteLine(results.Count()); // Will print 0

Any of these will cause the predicate to be evaluated against each item in the range... but before then, it won't be called at all.

This is an important thing to understand, because it means that results couldn't be null while retaining the feature of lazy evaluation - until you tried to use results, it wouldn't have worked out whether it should be null or not!


In this case it returns an IEnumerable<Int32> with a count of 0 items.


A reference to an empty IEnumerable<T>.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜