迭代器模式讲解
現在我們來學習迭代器模式,首先我們來看一下迭代器模式的定義與類型,首先呢他提供了一種方法,順序訪問一個集合對象中的各個元素,而又不暴露該對象的內部表示,簡單理解呢,是遍歷,大箱子,里面放了很多筆記本電腦,從上至下,我們從上之下數一下,比如戴爾電腦,第二個惠普電腦,第三個是蘋果電腦,那這個就是一個遍歷的過程
我們看一下迭代器的適用場景,首先訪問一個集合對象的內容,而無需暴露他的內部表示,第二項是為了遍歷不同的集合結構,提供一個統一的接口,也就是我去看一個箱子里面的電腦,還是看一個箱子里面的顯示器,其實都用一個迭代器,都OK的,為這個集合結構提供一個統一的接口
那迭代器的優點有哪些呢,首先分離了集合對象的遍歷行為,因為抽象出來一個迭代器,來負責這個集合對象的遍歷,這樣我們就可以讓外部的代碼,訪問集合內部的數據
那當然他肯定有缺點,缺點是什么呢,類的個數成對增加,那由于迭代器模式是將存儲數據和遍歷數據這兩個職責進行分離,所以如果我們新出現一種集合類,就需要增加集合類對應的新的迭代器類,也就是類的個數是成對增加的,那因為類的個數增加呢,在一定程度上就增加了類的復雜性
那我們再看一下迭代器相關的設計模式,首先是迭代器模式和訪問者模式,那這都是迭代的訪問一個對象中的元素,不同的是在訪問者模式當中,擴展開放的部分,在對象的操作上,而在迭代器模式中,擴展開放的部分,是在集合對象的種類上,那這兩種的實現方式,也有很大的區別,那在后面我們講訪問者模式的時候,也會來講一下
那接下來我們來看一下coding好的迭代器代碼,那這里面要強調一下,迭代器在我們日常使用當中,是非常廣泛的,但是我們使用的JDK,或者Guava,很多開源的項目當中,這些都會使用現成的迭代器,幾乎不會自己去寫一個迭代器,所以雖然他的使用范圍很廣,使用率很高,但是對于自己實現迭代器這種方式,平時很少看到,所以對于我們設計模式課程,有重點有非重點,我們一起來解讀寫好的迭代器的,實現代碼,然后也會來看一下UML,最后對迭代器在源碼中的應用,進行解析,那現在讓我們一起來解析迭代器模式的代碼
?
總結
- 上一篇: 模板方法源码解析(jdk+servlet
- 下一篇: 迭代器模式coding