当前位置: 首页 > 编程语言 > C# > 正文

C# 3.0特性 - 迭代器(下),yield以及流的延迟计算

时间:2010-12-03 博客园 横刀天笑

题目:从0遍历到20(不包括20),输出遍历到的每个元素,并将大于2的所有 数字放到一个IEnumerable中返回

解答1:(我以前经常这样做)

static IEnumerable<int> WithNoYield()
{
IList<int> list = new List<int>();
for (int i = 0; i < 20; i++)
{
Console.WriteLine(i.ToString());
if(i > 2)
list.Add(i);
}
return list;
}

解答2:(自从有了C# 2.0我 们还可以这样做)

static IEnumerable<int> WithYield()
{
for (int i = 0; i < 20; i++)
{
Console.WriteLine(i.ToString());
if(i > 2)
yield return i;
}
}

如果我用下面这样的代码测试,会得到 怎样的输出?

测试1:

测试WithNoYield()

static void Main()
{
WithNoYield();
Console.ReadLine();
}

测试WithYield()

static void Main()
{
WithYield();
Console.ReadLine();
}

测试2:

测试WithNoYield()

static void Main()
{
foreach (int i in WithNoYield())
{
Console.WriteLine(i.ToString());
}
Console.ReadLine();
}

测试WithYield()

static void Main()
{
foreach (int i in WithYield())
{
Console.WriteLine(i.ToString());
}
Console.ReadLine();
}