【设计模式】迭代器模式 ( 简介 | 适用场景 | 优缺点 | 代码示例 )
生活随笔
收集整理的這篇文章主要介紹了
【设计模式】迭代器模式 ( 简介 | 适用场景 | 优缺点 | 代码示例 )
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
文章目錄
- 一、迭代器模式簡介
- 二、迭代器模式適用場景
- 三、迭代器模式優(yōu)缺點
- 四、迭代器模式和訪問者模式
- 五、迭代器模式代碼示例
- 1、迭代器接口
- 2、迭代器實現
- 3、集合元素實例類
- 4、集合管理接口
- 5、集合管理實現類
- 6、測試類
一、迭代器模式簡介
迭代器模式 : 提供一種方法 , 順序訪問 集合對象 中的 各個元素 , 而 不暴露 該對象 的內部表示 ;
迭代器模式類型 : 行為型 ;
二、迭代器模式適用場景
迭代器模式適用場景 :
- 內容保密 : 訪問 集合對象 的內容 , 無需暴露內部表示 ;
- 統(tǒng)一接口 : 為遍歷 不同的 集合結構 , 提供統(tǒng)一接口 ;
三、迭代器模式優(yōu)缺點
迭代器模式優(yōu)點 : 分離 了 集合對象 的 遍歷行為 ; 抽象出了 迭代器 負責 集合對象的遍歷 , 可以讓外部的代碼 透明的 訪問集合內部的數據 ;
迭代器模式缺點 : 類的個數成對增加 ; 迭代器模式 , 將 存儲數據 , 遍歷數據 兩個職責拆分 ; 如果新添加一個 集合類 , 需要增加該 集合類 對應的 迭代器類 , 類的個數成對增加 , 在一定程度上 , 增加了系統(tǒng)復雜性 ;
四、迭代器模式和訪問者模式
迭代器模式和訪問者模式 : 兩個模式都是 迭代地 訪問集合對象中的元素 ,
- 訪問者模式 : 訪問者模式 中 , 擴展開放的部分 , 作用于對象的操作上 ;
- 迭代器模式 : 迭代器模式 中 , 擴展開放的部分 , 是在對象的種類上 ;
迭代器模式 , 應用廣泛 , 但是基本都使用 JDK 中提供的迭代器 , 不需要自己實現 ;
五、迭代器模式代碼示例
業(yè)務場景 : 使用迭代器模式 , 管理多個學生的信息 ;
1、迭代器接口
package iterator;public interface StudentIterator {/*** 獲取下一個學生對象* @return*/Student nextStudent();/*** 是否是最后一個* @return*/boolean isLast(); }
2、迭代器實現
package iterator;import java.util.ArrayList;public class StudentIteratorImpl implements StudentIterator{/*** 學生集合, 通過構造函數注入*/private ArrayList<Student> list;/*** 當前處理的集合索引*/private int position;/*** 當前處理的學生對象*/private Student student;public StudentIteratorImpl(ArrayList<Student> list) {this.list = list;}@Overridepublic Student nextStudent() {System.out.println("返回 " + position + " 位置的學生對象 : " + student);student = list.get(position);position++;return student;}@Overridepublic boolean isLast() {return position < list.size() ? false : true;} }
3、集合元素實例類
=package iterator;public class Student {String name;public Student(String name) {this.name = name;}public String getName() {return name;}@Overridepublic String toString() {return "Student{" +"name='" + name + '\'' +'}';} }
4、集合管理接口
package iterator;/*** 集合的管理類*/ public interface StudentAggregate {/*** 增加學生* @param student*/void addStudent(Student student);/*** 刪除學生*/void removeStudent(Student student);/*** 獲取學生集合的迭代器* @return*/StudentIterator getStudentIterator(); }
5、集合管理實現類
package iterator;import java.util.ArrayList;/*** 維護集合*/ public class StudentAggregateImpl implements StudentAggregate{/*** 學生集合*/private ArrayList<Student> list;public StudentAggregateImpl() {this.list = new ArrayList<>();}@Overridepublic void addStudent(Student student) {this.list.add(student);}@Overridepublic void removeStudent(Student student) {this.list.remove(student);}@Overridepublic StudentIterator getStudentIterator() {return new StudentIteratorImpl(this.list);} }
6、測試類
package iterator;public class Main {public static void main(String[] args) {// 創(chuàng)建 3 個學生對象Student tom = new Student("Tom");Student jerry = new Student("Jerry");Student trump = new Student("Trump");// 構造學生對象集合StudentAggregate studentAggregate = new StudentAggregateImpl();studentAggregate.addStudent(tom);studentAggregate.addStudent(jerry);studentAggregate.addStudent(trump);// 獲取學生對象的迭代器StudentIterator studentIterator = studentAggregate.getStudentIterator();// 判斷是否是最后一個對象 , 如果不是 , 獲取下一個對象 , 并打印while (!studentIterator.isLast()) {Student student = studentIterator.nextStudent();System.out.println(student);}// 刪除一個對象studentAggregate.removeStudent(trump);System.out.println("刪除 Trump" );studentIterator = studentAggregate.getStudentIterator();// 判斷是否是最后一個對象 , 如果不是 , 獲取下一個對象 , 并打印while (!studentIterator.isLast()) {Student student = studentIterator.nextStudent();System.out.println(student);}} }
執(zhí)行結果 :
返回 0 位置的學生對象 : null Student{name='Tom'} 返回 1 位置的學生對象 : Student{name='Tom'} Student{name='Jerry'} 返回 2 位置的學生對象 : Student{name='Jerry'} Student{name='Trump'} 刪除 Trump 返回 0 位置的學生對象 : null Student{name='Tom'} 返回 1 位置的學生對象 : Student{name='Tom'} Student{name='Jerry'}總結
以上是生活随笔為你收集整理的【设计模式】迭代器模式 ( 简介 | 适用场景 | 优缺点 | 代码示例 )的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【设计模式】策略模式 ( 简介 | 适用
- 下一篇: 【设计模式】模板方法模式 ( 简介 |