您好,登錄后才能下訂單哦!
無限序列意味著一個序列有無限多的元素。這似乎可以肯定,一般程序中內(nèi)存是有限的,不可能生成一個無限的序列。其實,這里的無限序列指的是可以取任意多個元素。常規(guī)方法去初始化一個序列是無法實現(xiàn)。因此只要通過其他方式才能曲線實現(xiàn)。
使用IEnumerable接口,可以實現(xiàn)無限序列。因為IEnumerable接口繼承于IEnumerator,因此實現(xiàn)了一個迭代器,也就是說,對于IEnumerable的實例(接口不能實例化,這里的意思指的是實現(xiàn)IEnumerable的類的實例)來說,可以使用迭代的方法依次遍歷它的元素。而且,IEnumerable的實例中的元素,并不是在定義的時候才有,而是在真正使用它的時候才會計算。因此我們可以在定義的時候定義一個無限的序列,而真正使用的時候,肯定只是取這個無限序列中的某幾個元素,這樣就只需迭代這幾個元素就行了。這就是延遲加載的好處。
具體實例如下,此處定義了一個無限的斐波納契序列。
static IEnumerable<int> fib() { int pre = 0; int next = 1; while (true) { var val = pre + next; yield return val; pre = next; next = val; } }
乍一看,看到while (true),就覺得這是一個死循環(huán),其實不然,里面有一個yield,每次迭代都會拋出值。while (true)里面的是迭代需要的循環(huán),因為是死循環(huán),也就是說可以迭代無數(shù)次。當然,如果你換成for循環(huán),并且循環(huán)次數(shù)設(shè)成10次,那么只能迭代10次,這是就只是一個普通的有限序列了。
在使用這個序列的時候,可以如下:
var f = fib();//此時并未真正開始計算里面的元素。
如果要取10個元素,可以通過linq的擴展方法Take(10)取元素,但是要知道,Take(10)這個函數(shù)也并未正真的去取10個數(shù),只有在真正用到的時候,才回去計算這些元素。
var list=f.Take(10);
下面的代碼要遍歷這個序列,此時才會正真去計算里面的元素值。
foreach (var i in list ) { Console.WriteLine(i); }
或者在Take(10)之后直接調(diào)用ToList,也能使得序列馬上計算其中的元素。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。