Java--设计模式-19-迭代器模式

简介: 迭代器模式(Iterator Pattern)就是不需要知道集合对象的底层内部逻辑,只通过访问一个方法就可以顺序访问集合对象的各个元素。属于行为型模式。

迭代器模式(Iterator Pattern)就是不需要知道集合对象的底层内部逻辑,只通过访问一个方法就可以顺序访问集合对象的各个元素。属于行为型模式。

       这玩意我们在日常开发中是一直在使用的,也正因为太常用,Java内部已经提供了这个接口:util包下的Iterator接口,实现这个接口就可以得到一个迭代器。

image.png

       那么得到了这个迭代器后,我们怎么用到要遍历的类上呢?这里就又涉及到另外一个接口:lang包下的Iterable接口

image.png

       上图那句可以看到,Iterator<T> iterator()方法就是要return一个迭代器啦,这两个接口配合使用,我们就可以对我们的类进行迭代来获取类的内部元素啦。

       这里直接看常用的ArrayList就可以,看源码:

ArrayList是Collection的继承类,统一由Collection实现了Iterable接口

image.png

然后来看ArrayList的源码:

image.png

       我们要让自定义的类支持迭代怎么实现呢?

1.建一个实现了Iterable的类

packagecom.xing.design.iterator;
importjava.util.ArrayList;
importjava.util.Iterator;
importjava.util.List;
/*** 相当于List,可以迭代* @author xing* @createTime*/publicclassMyListimplementsIterable<String>{
privatefinalList<String>strList=newArrayList<>();
publicMyList() {
strList.add("第一个元素");
strList.add("第二个元素");
strList.add("第三个元素");
  }
@OverridepublicIterator<String>iterator() {
returnnewMyIterator();
  }
/***  内部类是一个迭代器哈* @author xing* @createTime*/privateclassMyIteratorimplementsIterator<String> {
intindex=0;
@OverridepublicbooleanhasNext() {
returnindex<strList.size()?true :false;
    }
@OverridepublicStringnext() {
Stringstr=strList.get(index);
index++;
returnstr;
    }
  }
}

2.编写main方法测试

packagecom.xing.design.iterator;
importjava.util.Iterator;
publicclassIteratorDemo {
publicstaticvoidmain(String[] args) {
MyListmyList=newMyList();
// 获取我们得到的那个迭代器Iterator<String>iterator=myList.iterator();
while (iterator.hasNext()){
System.out.println(iterator.next());
    }
for (Stringstr : myList) {
System.out.println(str);
    }
  }
}

3.测试结果

image.png

       完美,就这么简单。。。


总结:

       迭代器模式在Java中很常用,我们使用Collection系列的集合基本上已经能满足大部分情况。如果要自定义类迭代就实现Iterable接口。

       迭代器模式分离了集合对象的遍历行为,抽象出一个迭代器类来负责,这样既可以做到不暴露集合的内部结构,又可让外部代码透明地访问集合内部的数据。


END

目录
相关文章
|
12天前
|
设计模式 Java
【设计模式】JAVA Design Patterns——Bridge(桥接模式)
【设计模式】JAVA Design Patterns——Bridge(桥接模式)
【设计模式】JAVA Design Patterns——Bridge(桥接模式)
|
7天前
|
设计模式 Java 数据库连接
【重温设计模式】代理模式及其Java示例
【重温设计模式】代理模式及其Java示例
|
11天前
|
设计模式 Java API
【设计模式】JAVA Design Patterns——Combinator(功能模式)
【设计模式】JAVA Design Patterns——Combinator(功能模式)
|
12天前
|
设计模式 监控 Java
【设计模式】JAVA Design Patterns——Circuit Breaker(断路器模式)
【设计模式】JAVA Design Patterns——Circuit Breaker(断路器模式)
|
12天前
|
设计模式 Java 程序员
【设计模式】JAVA Design Patterns——Bytecode(字节码模式)
【设计模式】JAVA Design Patterns——Bytecode(字节码模式)
|
12天前
|
设计模式 算法 Java
【设计模式】JAVA Design Patterns——Builder(构造器模式)
【设计模式】JAVA Design Patterns——Builder(构造器模式)
|
12天前
|
设计模式 Java 容器
【设计模式】JAVA Design Patterns——Async Method Invocation(异步方法调用模式)
【设计模式】JAVA Design Patterns——Async Method Invocation(异步方法调用模式)
|
4天前
|
设计模式 存储 前端开发
Java的mvc设计模式在web开发中应用
Java的mvc设计模式在web开发中应用
|
7天前
|
设计模式 安全 Java
【设计模式】JAVA Design Patterns——Curiously Recurring Template Pattern(奇异递归模板模式)
该文介绍了一种C++的编程技巧——奇异递归模板模式(CRTP),旨在让派生组件能继承基本组件的特定功能。通过示例展示了如何创建一个`Fighter`接口和`MmaFighter`类,其中`MmaFighter`及其子类如`MmaBantamweightFighter`和`MmaHeavyweightFighter`强制类型安全,确保相同重量级的拳手之间才能进行比赛。这种设计避免了不同重量级拳手间的错误匹配,编译时会报错。CRTP适用于处理类型冲突、参数化类方法和限制方法只对相同类型实例生效的情况。
【设计模式】JAVA Design Patterns——Curiously Recurring Template Pattern(奇异递归模板模式)
|
9天前
|
设计模式 Java 数据库
【设计模式】JAVA Design Patterns——Converter(转换器模式)
转换器模式旨在实现不同类型间的双向转换,减少样板代码。它通过通用的Converter类和特定的转换器(如UserConverter)简化实例映射。Converter类包含两个Function对象,用于不同类型的转换,同时提供列表转换方法。当需要在逻辑上对应的类型间转换,或处理DTO、DO时,此模式尤为适用。
【设计模式】JAVA Design Patterns——Converter(转换器模式)