プロジェクトのソースアドレスします。https://github.com/ggb2312/JavaNotes/tree/master/design-pattern(デザインパターン、関連するコードやメモ)
1.定義
そこを順次オブジェクトの内部表現を公開せず、コレクションオブジェクトの各要素にアクセスする方法が提供されます
2.該当シーン
- その内部表現を暴露することなく、オブジェクトのコレクションの内容にアクセス
- 異なるセットを横切る構造が統一されたインタフェースを提供します
3.クラス図と役割
反復子の役割(イテレータ):現在のオブジェクトのうちトラバーサルのhasNext端())か否かを判断するのnext()メソッドの次の要素を取得するための方法であって、定義するために必要な要素を横断する方法であって、一般的に、そう3つの方法がありますメソッドRemove()
特定のロール・イテレータ(コンクリートイテレータ):定義された実装方法のイテレータインターフェース反復セット
ロールコンテナ(集合体):通常、インタフェースは、例えば、反復子()方法を提供することで、Javaのコレクション、リストインターフェース、セットインタフェースにインタフェース
コンテナ(ConcreteAggregate)の具体的な役割は: HashSetのLINKLIST、インターフェースの設定ハッシュリストなどを達成するためのArrayList、インタフェースの一覧リストの実装を達成するために、このような順序付きリストの一覧・インターフェースとして抽象クラスコンテナの具体的な実現であり、
4.関連するデザインパターン
イテレータパターンとVisitorパターン
- 同じことは:両方のオブジェクトのコレクションに繰り返しアクセスされています
- 異なる:Visitorパターンは、オブジェクトに作用する、開口部を拡張しました。反復モードは、開口部を拡張し、種類に設定されています。
例5モード
クラスのコースがあります:
public class Course {
private String name;
public Course(String name) {
this.name = name;
}
public String getName() {
return name;
}
}
またCourseAggregateインタフェース、カリキュラムのプロセスがあります:
public interface CourseAggregate {
void addCourse(Course course);
void removeCourse(Course course);
/**获取迭代器 */
CourseIterator getCourseIterator();
}
これは、インタフェースの実装クラスに対処することです:
public class CourseAggregateImpl implements CourseAggregate {
private List courseList;
public CourseAggregateImpl() {
this.courseList = new ArrayList();
}
@Override
public void addCourse(Course course) {
courseList.add(course);
}
@Override
public void removeCourse(Course course) {
courseList.remove(course);
}
@Override
public CourseIterator getCourseIterator() {
return new CourseIteratorImpl(courseList);
}
}
これは、Iteratorインターフェイスです。
public interface CourseIterator {
Course nextCourse();
boolean isLastCourse();
}
そして、これはIteratorインターフェイスの実装クラスです。
public class CourseIteratorImpl implements CourseIterator {
private List courseList;
private int position;
private Course course;
public CourseIteratorImpl(List courseList){
this.courseList=courseList;
}
@Override
public Course nextCourse() {
System.out.println("返回课程,位置是: "+position);
course=(Course)courseList.get(position);
position++;
return course;
}
@Override
public boolean isLastCourse(){
if(position< courseList.size()){
return false;
}
return true;
}
}
試験方法:
public class Test {
public static void main(String[] args) {
Course course1 = new Course("Java电商一期");
Course course2 = new Course("Java电商二期");
Course course3 = new Course("Java设计模式精讲");
Course course4 = new Course("Python课程");
Course course5 = new Course("算法课程");
Course course6 = new Course("前端课程");
CourseAggregate courseAggregate = new CourseAggregateImpl();
courseAggregate.addCourse(course1);
courseAggregate.addCourse(course2);
courseAggregate.addCourse(course3);
courseAggregate.addCourse(course4);
courseAggregate.addCourse(course5);
courseAggregate.addCourse(course6);
System.out.println("-----课程列表-----");
printCourses(courseAggregate);
courseAggregate.removeCourse(course4);
courseAggregate.removeCourse(course5);
System.out.println("-----删除操作之后的课程列表-----");
printCourses(courseAggregate);
}
public static void printCourses(CourseAggregate courseAggregate){
CourseIterator courseIterator= courseAggregate.getCourseIterator();
while(!courseIterator.isLastCourse()){
Course course=courseIterator.nextCourse();
System.out.println(course.getName());
}
}
}
テスト結果:
このクラス図では:
6.長所と短所
利点:
- オブジェクトの孤立トラバーサル行動コレクション
短所:
- クラスのペアの数を増やします
7. 拡張-JDK1.7源と反復フレームモード
7.1 JDK
java.util.Iteratorの
java.util.ArrayListの中的Itrは
7.2 MyBatisの
org.apache.ibatis.cursor.defaults.DefaultCursor的cursorIterator