我有一系列的元素该序列只能重复一次,可以是“无限”.
什么是最好的方式得到这样一个序列的头和尾?
解决方法
分解IEnumerable< T>进入头尾部对于递归处理(与功能列表不同)不是特别好,因为当您以递归方式使用尾部操作时,您将创建一些指令.但是,您可以这样写:
我忽略了参数检查和异常处理等事情,但它显示了这个想法…
- Tuple<T,IEnumerable<T>> HeadAndTail<T>(IEnumerable<T> source) {
- // Get first element of the 'source' (assuming it is there)
- var en = source.GetEnumerator();
- en.MoveNext();
- // Return first element and Enumerable that iterates over the rest
- return Tuple.Create(en.Current,EnumerateTail(en));
- }
- // Turn remaining (unconsumed) elements of enumerator into enumerable
- IEnumerable<T> EnumerateTail<T>(IEnumerator en) {
- while(en.MoveNext()) yield return en.Current;
- }
HeadAndTail方法获取第一个元素并将其作为元组的第一个元素返回.元组的第二个元素是IEnumerable< T>这是从剩余元素生成的(通过迭代我们已经创建的枚举器的其余部分).