序列就是可迭代的,是一个迭代器,也就是实现了IEnumerable接口的。
列表就是内存中的元素的集合。容易读写,通常以索引的方式访问。
用函数方法实现迭代器
private static IEnumerable<T> Sequence<T>(Func<T, T> getNext, T startValue, Func<T, bool> endReached) { if (getNext==null) { yield break; } yield return startValue; T val = startValue; while (endReached==null||!endReached(val)) { val = getNext(val); yield return val; } }
验证
var s = Sequence(x => x + 2, 1,x=>x>=19); foreach (var i in s) { Console.WriteLine(i); }
输出
总结:
1、序列都实现了IEnumerable接口,是迭代器。用foreach访问。
2、函数可以作为参数传递给另一个函数,例如x=>x+2 就是委托(委托是匿名函数)。
3、对上面Sequence函数的解释:(1)是泛型函数(2)getNext对迭代值操作,如果x=>x+2换成x=>x*3,就是对每一个迭代元素都增加3倍。
(3)endReched是迭代结束条件。