我在MSDN中见过这种语法:yield break,但我不知道它是做什么的。有人知道吗?
当前回答
yield关键字与return关键字一起使用,为枚举器对象提供一个值。Yield return指定返回的值。当到达yield return语句时,存储当前位置。下次调用迭代器时,从这个位置重新开始执行。
用一个例子来解释它的意思:
public IEnumerable<int> SampleNumbers() { Int counter = 0; 收益回报计数器; 计数器=计数器+ 2; 收益回报计数器; 计数器=计数器+ 3; 收益回报计数器; }
迭代时返回的值为:0,2,5。
值得注意的是,本例中的counter变量是一个局部变量。在第二次迭代返回值2之后,第三次迭代从之前的位置开始,同时保留名为counter的局部变量之前的值2。
其他回答
yield break语句导致枚举停止。实际上,yield break完成了枚举,而不返回任何附加项。
考虑到迭代器方法实际上有两种停止迭代的方式。在一种情况下,方法的逻辑可以在返回所有项后自然退出方法。这里有一个例子:
IEnumerable<uint> FindPrimes(uint startAt, uint maxCount)
{
for (var i = 0UL; i < maxCount; i++)
{
startAt = NextPrime(startAt);
yield return startAt;
}
Debug.WriteLine("All the primes were found.");
}
在上面的例子中,一旦找到maxCount质数,迭代器方法自然会停止执行。
yield break语句是迭代器停止枚举的另一种方式。这是一种提前跳出枚举的方法。这里是与上面相同的方法。这一次,该方法对该方法可以执行的时间有一个限制。
IEnumerable<uint> FindPrimes(uint startAt, uint maxCount, int maxMinutes)
{
var sw = System.Diagnostics.Stopwatch.StartNew();
for (var i = 0UL; i < maxCount; i++)
{
startAt = NextPrime(startAt);
yield return startAt;
if (sw.Elapsed.TotalMinutes > maxMinutes)
yield break;
}
Debug.WriteLine("All the primes were found.");
}
注意yield break的调用。实际上,它提早退出枚举。
还要注意,yield break与普通break的工作方式不同。在上面的例子中,yield break退出方法而不调用Debug.WriteLine(..)。
结束迭代器块(例如,表示IEnumerable中没有更多的元素)。
告诉迭代器它已经到达终点。
举个例子:
public interface INode
{
IEnumerable<Node> GetChildren();
}
public class NodeWithTenChildren : INode
{
private Node[] m_children = new Node[10];
public IEnumerable<Node> GetChildren()
{
for( int n = 0; n < 10; ++n )
{
yield return m_children[ n ];
}
}
}
public class NodeWithNoChildren : INode
{
public IEnumerable<Node> GetChildren()
{
yield break;
}
}
它指定迭代器已经结束。您可以将yield break看作一个不返回值的return语句。
例如,如果你将一个函数定义为迭代器,函数体可能是这样的:
for (int i = 0; i < 5; i++)
{
yield return i;
}
Console.Out.WriteLine("You will see me");
注意,在循环完成所有循环后,最后一行执行,您将在控制台应用程序中看到消息。
或者像这样的yield break:
int i = 0;
while (true)
{
if (i < 5)
{
yield return i;
}
else
{
// note that i++ will not be executed after this
yield break;
}
i++;
}
Console.Out.WriteLine("Won't see me");
在这种情况下,最后一条语句永远不会执行,因为我们提前离开了函数。
yield关键字与return关键字一起使用,为枚举器对象提供一个值。Yield return指定返回的值。当到达yield return语句时,存储当前位置。下次调用迭代器时,从这个位置重新开始执行。
用一个例子来解释它的意思:
public IEnumerable<int> SampleNumbers() { Int counter = 0; 收益回报计数器; 计数器=计数器+ 2; 收益回报计数器; 计数器=计数器+ 3; 收益回报计数器; }
迭代时返回的值为:0,2,5。
值得注意的是,本例中的counter变量是一个局部变量。在第二次迭代返回值2之后,第三次迭代从之前的位置开始,同时保留名为counter的局部变量之前的值2。
推荐文章
- 并发HashSet<T>在。net框架?
- 从控制器内获得控制器和动作名称?
- _ViewStart的位置和方式。CSHTML布局文件链接?
- 新建T()
- 如何将枚举绑定到WPF中的组合框控件?
- 拒绝访问该路径
- Visual Studio - Resx文件默认“内部”为“公共”
- 使用linq转换列表到字典,不用担心重复
- 单元测试:日期时间。现在
- 什么是回调?
- .NET中的KeyDown和KeyPress有什么区别?
- 返回匿名类型的结果?
- 你能解释一下流的概念吗?
- 何时使用IList,何时使用List
- ConfigurationManager。AppSettings在.NET Core 2.0中可用?