一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

不能不說的C#特性-迭代器(上)及一些研究過程中的副產品

系列文章導航:

走進Linq--Linq橫空出世篇

走進Linq-輝煌的背后

走進Linq-Linq大觀園

不能不說的C#特性-對象集合初始化器

不能不說的C#特性-匿名類型與隱式類型局部變量

不能不說的C#特性-擴展方法

不能不說的C#特性-匿名方法和Lambda表達式

不能不說的C#特性-迭代器(上)及一些研究過程中的副產品

不能不說的C#特性-迭代器(下),yield以及流的延遲計算

走進Linq-Linq to Objects(上)基礎篇

走進Linq-Linq to Objects(下)實例篇

走進Linq-Linq to SQL感性認識篇

走進Linq-Linq to SQL How do I(1)

走進Linq-Linq to SQL How do I(2)

走進Linq-Linq to SQL How do I(3)

走進Linq-How do I(4)拾遺補零篇第一節

走進Linq-Linq to SQL源代碼賞析 Table的獲取過程

走進Linq-Linq to SQL源代碼賞析之Provider的初始化

走進Linq-Linq to SQL源代碼賞析,通過Linq to SQL看Linq


提到迭代器我們不能不想到迭代器模式,那我就以迭代器模式作為開場白。

在我們的應用程序中常常有這樣一些數據結構:

它們是一個數據的集合,如果你知道它們內部的實現結構就可以去訪問它們,它們各自的內部存儲結構互不相同,各種集合有各自的應用場合.說到這里大家可能想出一大堆這樣的集合了:List,Hashtable,ArrayList等等。這些集合各自都有各自的個性,這就是它們存在的理由。但如果你想遍歷它你必須知道它內部的存儲細節,作為一個集合元素,把內部細節暴露出來肯定就不好了,這樣客戶程序就不夠穩定了,在你更換集合對象的時候,比如List不能滿足需求的時候,你換成Hashtable,因為以前的客戶程序過多的關注了List內部實現的細節,所以不能很好的移植。而迭代器模式就是為解決這個問題而生的:

提供一種一致的方式訪問集合對象中的元素,而無需暴露集合對象的內部表示。

比如現在有這樣一個需求,遍歷集合內的元素,然后輸出,但是并不限定集合是什么類型的集合,也就是未來集合可能發生改變。

思考:

集合會發生改變,這是變化點,集合改變了,遍歷方法也改變,我們要保證遍歷的方法穩定,那么就要屏蔽掉細節。找到了變化點那我們就將其隔離起來(一般使用interface作為隔離手段):假設所有的集合都繼承自ICollection接口,這個接口用來隔離具體集合的,將集合屏蔽在接口后面,作為遍歷我們肯定需要這樣一些方法:MoveNext,Current,既然ICollection負責數據存儲,職責又要單一,那么就新建立一個接口叫做Iterator吧,每種具體的集合都有自己相對應的Iterator實現:

下面是一個簡易的實現代碼:

/// 
/// 集合的接口
/// 
    public interface ICollection
    {
        
int Count { get; }
        
/// 
        
/// 獲取迭代器
        
/// 
        
/// 迭代器
        Iterator GetIterator();
    }
    
/// 
    
/// 迭代器接口
    
/// 
    public interface Iterator
    {
        
bool MoveNext();

        
object Current { get; }
    }

    
public class List : ICollection
    {
        
private const int MAX = 10;
        
private object[] items;
        
public List()
        { 
            items 
= new object[MAX];
        }
        
public object this[int i]
        {
            
get { return items[i]; }
            
set { this.items[i] = value; }
        }
        
#region ICollection Members

        
public int Count
        {
            
get { return items.Length; }
        }

        
public Iterator GetIterator()
        {
            
return new ListIterator(this);
        }

        
#endregion
    }
    
public class ListIterator : Iterator
    {
        
private int index = 0;
        
private ICollection list;
        
public ListIterator(ICollection list)
        {
            
this.list = list;
            index 
= 0;
        }
        
#region Iterator Members

        
public bool MoveNext()
        {
            
if (index + 1 > list.Count)
                
return false;
            
else
            { 
                index
++;
                
return true;
            }
        }

        
public object Current
        {
            
get { return list[index]; }
        }

        
#endregion
    }
    
/// 
    
/// 測試
    
/// 
    public class Program
    {
        
static void Main()
        {
            ICollection list 
= new List();
            Iterator iterator 
= list.GetIterator();
            
while (iterator.MoveNext())
            {
                
object current = iterator.Current;
            }
        }
}

系列文章導航:

走進Linq--Linq橫空出世篇

走進Linq-輝煌的背后

走進Linq-Linq大觀園

不能不說的C#特性-對象集合初始化器

不能不說的C#特性-匿名類型與隱式類型局部變量

不能不說的C#特性-擴展方法

不能不說的C#特性-匿名方法和Lambda表達式

不能不說的C#特性-迭代器(上)及一些研究過程中的副產品

不能不說的C#特性-迭代器(下),yield以及流的延遲計算

走進Linq-Linq to Objects(上)基礎篇

走進Linq-Linq to Objects(下)實例篇

走進Linq-Linq to SQL感性認識篇

走進Linq-Linq to SQL How do I(1)

走進Linq-Linq to SQL How do I(2)

走進Linq-Linq to SQL How do I(3)

走進Linq-How do I(4)拾遺補零篇第一節

走進Linq-Linq to SQL源代碼賞析 Table的獲取過程

走進Linq-Linq to SQL源代碼賞析之Provider的初始化

走進Linq-Linq to SQL源代碼賞析,通過Linq to SQL看Linq


看看最后的測試,是不是不管具體的集合如何改變,遍歷代碼都非常穩定?而且擴展新的集合類也非常方便,只是添加代碼不會修改原來的代碼,符合開閉原則。當然,這么好的解決方案微軟當然不會放過,現在C# 2.0里已經內置了對迭代器的支持,看看System.Collections, System.Collections.Generic命名空間,所有的集合都實現了這個接口:IEnumerable,這個接口還有泛型的版本。注意到這個接口只有一個方法:IEnumerator GetEnumerator();,IEnumerator就是迭代器的接口,相當于我的實例里面的Iterator,它也有泛型的版本。

那么現在在.NET里所有的集合類都可以這樣訪問了:

IEnumerator ienumerator = list.GetEnumerator();
while(ienumerator.MoveNext())
{
    
object current = ienumerator.Current;
}

系列文章導航:

走進Linq--Linq橫空出世篇

走進Linq-輝煌的背后

走進Linq-Linq大觀園

不能不說的C#特性-對象集合初始化器

不能不說的C#特性-匿名類型與隱式類型局部變量

不能不說的C#特性-擴展方法

不能不說的C#特性-匿名方法和Lambda表達式

不能不說的C#特性-迭代器(上)及一些研究過程中的副產品

不能不說的C#特性-迭代器(下),yield以及流的延遲計算

走進Linq-Linq to Objects(上)基礎篇

走進Linq-Linq to Objects(下)實例篇

走進Linq-Linq to SQL感性認識篇

走進Linq-Linq to SQL How do I(1)

走進Linq-Linq to SQL How do I(2)

走進Linq-Linq to SQL How do I(3)

走進Linq-How do I(4)拾遺補零篇第一節

走進Linq-Linq to SQL源代碼賞析 Table的獲取過程

走進Linq-Linq to SQL源代碼賞析之Provider的初始化

走進Linq-Linq to SQL源代碼賞析,通過Linq to SQL看Linq


調用迭代器的MoveNext()方法,L_004e: brtrue.s L_0036 如果是true的話跳轉,

L_0036: ldloc.2 
L_0037: callvirt instance object [mscorlib]System.Collections.IEnumerator::get_Current()
L_003c: stloc.1 
L_003d: ldloc.1 
L_003e: callvirt instance string [mscorlib]System.Object::ToString()
L_0043: call void [mscorlib]System.Console::WriteLine(string)

it知識庫不能不說的C#特性-迭代器(上)及一些研究過程中的副產品,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 午夜视频91| 亚洲综合图片区 | 中文字幕一区二区三 | 一级韩国aa毛片免费观看 | 午夜视频在线观看网站 | 综合国产在线 | 91视频社区 | 成人午夜视频免费观看 | 综合久久久久久中文字幕 | 国产真实伦正在播放 | 91热久久免费频精品99欧美 | 男女性色大片免费网站 | 亚洲成在人色婷婷 | 全国最大色成免费网站 | 97成人在线 | 久久er这里都是精品23 | 国产精品制服诱惑 | 色视频观看| 精品国产麻豆免费网站 | 欧美成年黄网站色高清视频 | 久久久久久久成人午夜精品福利 | 日本大臿亚洲香蕉大片 | 久久亚洲精品中文字幕三区 | 精品一区二区三区免费站 | 久久瑟 | 久久久国产精品va麻豆 | 欧美一级在线全免费 | 亚洲精品自在线拍 | 韩国理论福利片午夜 | 欧美福利网站 | 欧洲成人在线 | 91中文字幕在线视频 | 2021国内精品久久久久影院 | 国内精品国语自产拍在线观看91 | 不良网站在线观看 | 国产精品自产拍视频观看 | 毛片无遮挡 | 欧美激性欧美激情在线 | 精品综合久久久久久98 | 成 人 色综合 | 欧美成人精品欧美一级乱黄 |