我有一系列的元素该序列只能重复一次,可以是“无限”.
什么是最好的方式得到这样一个序列的头和尾?
解决方法
分解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>这是从剩余元素生成的(通过迭代我们已经创建的枚举器的其余部分).