自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

C#迭代器模式分析

開發(fā) 后端
這里介紹C#迭代器模式,以前的客戶程序過多的關注了List內(nèi)部實現(xiàn)的細節(jié),所以不能很好的移植。而C#迭代器模式就是為解決這個問題而生的。

C#迭代器有很多值得學習的地方,這里我們主要介紹C#迭代器模式,包括介紹ICollection負責數(shù)據(jù)存儲等方面。

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

在我們的應用程序中常常有這樣一些數(shù)據(jù)結(jié)構(gòu):

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

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

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

思考:

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

  1. public interface ICollection  
  2. {  
  3. int Count { get; }  
  4. ///   
  5. /// 獲取迭代器  
  6. ///   
  7. /// 迭代器  
  8. Iterator GetIterator();  
  9. }  
  10. ///   
  11. /// 迭代器接口  
  12. ///   
  13. public interface Iterator  
  14. {  
  15. bool MoveNext();  
  16.  
  17. object Current { get; }  
  18. }  
  19.  
  20. public class List : ICollection  
  21. {  
  22. private const int MAX = 10;  
  23. private object[] items;  
  24. public List()  
  25. {   
  26. items = new object[MAX];  
  27. }  
  28. public object this[int i]  
  29. {  
  30. get { return items[i]; }  
  31. set { this.items[i] = value; }  
  32. }  
  33. #region ICollection Members  
  34.  
  35. public int Count  
  36. {  
  37. get { return items.Length; }  
  38. }  
  39.  
  40. public Iterator GetIterator()  
  41. {  
  42. return new ListIterator(this);  
  43. }  
  44.  
  45. #endregion  
  46. }  
  47. public class ListIterator : Iterator  
  48. {  
  49. private int index = 0;  
  50. private ICollection list;  
  51. public ListIterator(ICollection list)  
  52. {  
  53. this.list = list;  
  54. index = 0;  
  55. }  
  56. #region Iterator Members  
  57.  
  58. public bool MoveNext()  
  59. {  
  60. if (index + 1 > list.Count)  
  61. return false;  
  62. else  
  63. {   
  64. index++;  
  65. return true;  
  66. }  
  67. }  
  68.  
  69. public object Current  
  70. {  
  71. get { return list[index]; }  
  72. }  
  73.  
  74. #endregion  
  75. }  
  76. ///   
  77. /// 測試  
  78. ///   
  79. public class Program  
  80. {  
  81. static void Main()  
  82. {  
  83. ICollection list = new List();  
  84. Iterator iterator = list.GetIterator();  
  85. while (iterator.MoveNext())  
  86. {  
  87. object current = iterator.Current;  
  88. }  
  89. }  

【編輯推薦】

  1. C# lock關鍵字敘述
  2. C#.Net FrameWork簡介
  3. C# new和override簡單描述
  4. C#值類型和引用類型淺談
  5. C#標識符簡單分析
責任編輯:佚名 來源: IT168
相關推薦

2009-08-11 13:59:41

迭代器模式C# Iterator

2009-08-19 15:18:53

迭代器

2009-08-26 16:37:07

C#迭代器局部變量

2009-08-31 16:01:31

C#和設計模式

2013-03-15 10:37:08

C#

2021-06-22 15:27:13

設計模式迭代器模式Java

2010-04-29 08:53:11

PHP迭代器模式

2020-11-06 09:01:46

迭代器模式

2009-08-26 10:24:04

C# Observer

2009-08-31 16:12:02

C#使用Singlet

2023-11-07 10:10:36

設計模式元素

2009-08-27 13:27:50

C# this保留字

2009-08-26 10:34:59

C# Hashtabl

2009-09-01 09:16:57

C#使用SharpZi

2009-08-19 11:21:02

C# ListBox控

2009-08-26 16:46:06

C# ThreadSt

2009-08-04 09:22:26

C#工廠模式

2009-09-02 16:23:27

C# Singleto

2009-08-25 18:04:30

C#實現(xiàn)Singlet

2009-08-31 15:48:02

C# Singleto
點贊
收藏

51CTO技術(shù)棧公眾號