楼上回答的,都不太详细,我没懂起。 执行p.GetResult(),方法都不执行吗?是的,不执行,如果你在main方法中这么写,var result=p.GetResult(); foreach(var element in result) { 操作; }这时候访问了迭代器的结果集,就会执行到。你可以再GetResult里面打个断点看看,看是不是foreach的时候才执行,你可以把result这个变量看成一个"委托",调用的时候才执行。至于为什么延迟执行,我的理解应该是和Linq的延迟查询特性一样,越晚被执行,对业务逻辑的理解就越清晰,LINQ查询对数据的请求压力越小。编译器对LINQ查询优化可作的事情越多。
p.GetResult().GetEnumerator().MoveNext();
"Deferred execution is supported directly in the C# language by the yield keyword "来自msdn, lz可以读一下:
Deferred Execution and Lazy Evaluation in LINQ to XML
http://msdn.microsoft.com/en-us/library/vstudio/bb943859(v=vs.100).aspx
执行p.GetResult(),方法都不执行吗?
执行p.GetResult(),方法都不执行吗?是的,不执行,如果你在main方法中这么写,var result=p.GetResult();
foreach(var element in result)
{
操作;
}这时候访问了迭代器的结果集,就会执行到。你可以再GetResult里面打个断点看看,看是不是foreach的时候才执行,你可以把result这个变量看成一个"委托",调用的时候才执行。至于为什么延迟执行,我的理解应该是和Linq的延迟查询特性一样,越晚被执行,对业务逻辑的理解就越清晰,LINQ查询对数据的请求压力越小。编译器对LINQ查询优化可作的事情越多。
这个主要是对yield关键字的理解,参考下吧~
使用 foreach 语句或 LINQ 查询,则使用迭代器方法。 foreach 循环的每次迭代调用迭代器方法。 当 yield return 语句在迭代器方法时为止,expression 返回,并且,代码的当前位置保留。 当下次调用迭代器函数时执行从该位置重新启动。
可以使用 yield break 语句结束迭代。
http://msdn.microsoft.com/zh-cn/library/9k7k7cf0.aspx
执行p.GetResult(),方法都不执行吗?
执行p.GetResult()返回一个迭代器,但是并不执行其中的代码。
执行p.GetResult(),方法都不执行吗?
执行p.GetResult()返回一个迭代器,但是并不执行其中的代码。MSDN不是说包含yield return的整个方法就叫做迭代器吗?怎么你又说执行p.GetResult()返回一个迭代器呢?
执行p.GetResult(),方法都不执行吗?
执行p.GetResult()返回一个迭代器,但是并不执行其中的代码。MSDN不是说包含yield return的整个方法就叫做迭代器吗?怎么你又说执行p.GetResult()返回一个迭代器呢?这个实现比较复杂,C#编译器会将你这个方法拆开,变成3个方法,并且在内部维护一个状态机。p.GetResult()相当于初始化迭代器。
itl.MoveNext();
itl.MoveNext();
itl.MoveNext();
itl.MoveNext(); public IEnumerable<int> GetResult()
{
Console.WriteLine("0");
yield return 1;
Console.WriteLine("1");
yield return 2;
Console.WriteLine("2");
yield return 3;
Console.WriteLine("3");
yield return 4;
Console.WriteLine("4");
yield break;
}你调试下这段代码,自己再想想