设计模式之——迭代器模式
设计模式是开发者前辈们给我们后背的一个经验总结。有效的使用设计模式,能够帮助我们编写可复用的类。所谓“可复用”,就是指将类实现为一个组件,当一个组件发生改变时,不需要对其他组件进行修改,或者只需要修改很小一部分即可。
迭代器模式(Iterator),提供一种方法顺序访问一个聚合对象中的各种元素,而又不暴露该对象的内部表示。
下面是一段实现了迭代器模式的示例程序,这段程序作用是,将书BOOK放到书架中BookShelf,并且采用迭代器的方式进行遍历,将书名按照顺序显示出来:
- Aggregate接口,作为自定义集合的顶层接口。
package site.wangxin520.gof.iterator; /**
* 定义表示集合的接口,有一个iterator方法,用于返回一个Iterator类
* @author wangXgnaw
*
*/
public interface Aggregate { /**
* 集合的获取迭代器方法,用于返回一个迭代器对象
* @return Iterator 返回一个迭代器对象
*/
public Iterator iterator();
}
- Iterator迭代器的顶层父接口
package site.wangxin520.gof.iterator; /**
* 这个是迭代器的类,里面有两个方法,hasnext和next
* @author wangXgnaw
*
*/
public interface Iterator { /**
* 判断是否有下一个元素,通常使用在while进行遍历
* @return boolean
*/
public boolean hasNext(); /**
* 返回当前指针指向的元素,并且把指针指向下一个元素
* @return Object 返回一个对象,集合的单个元素对象
*/
public Object next();
}
- BookShelf书架的类,实现了集合的接口
package site.wangxin520.gof.iterator; import java.util.ArrayList; /**
* 用于表示书架用的类,实现了集合的这个接口。 实际在Java中,集合的顶层接口也是同样的方式。
*
* @author wangXgnaw
*
*/
public class BookShelf implements Aggregate { /**
* 集合,用于保存书的
*/
private ArrayList<Book> list = new ArrayList<Book>(); /**
* 获取到书架的大小
*
* @return int
*/
public int size() {
return list.size();
} /**
* 往书架里面放书
* @param book
*/
public void putBook(Book book) {
list.add(book);
} /**
* 根据序号,从书架里面取书
*
* @param index
* @return Book
*/
public Book getBook(int index) {
return list.get(index);
} public Iterator iterator() {
return new BookShelfIterator(this);
} }
- 书架的迭代器实现,这需要自己定义,以实现迭代器接口定义的方法。
package site.wangxin520.gof.iterator; /**
* 书架的一个迭代器
* @author wangXgnaw
*
*/
public class BookShelfIterator implements Iterator{ /**
* 书架属性,用于对迭代器进行操作需要的。
*/
private BookShelf bookShelf; /**
* 当前指针指向的位置
*/
private int index=0; /**
* 书架类迭代器的构造函数
* @param bookShelf
*/
public BookShelfIterator(BookShelf bookShelf){
this.bookShelf=bookShelf;
} public boolean hasNext() {
if(index<bookShelf.size()){
return true;
}
return false;
} public Object next() {
//获取指定编号的书
Book book = bookShelf.getBook(index);
//指针向下移动一个
index++;
return book;
} }
- Book书的实体类
package site.wangxin520.gof.iterator; /**
* 书的实体类
* @author wangXgnaw
*
*/
public class Book {
/**
* 数的名字
*/
private String bookName; /**
* 书本的构造函数,传入书本的名字。
* @param name
*/
public Book(String name){
this.bookName=name;
} public String getBookName() {
return bookName;
} public void setBookName(String bookName) {
this.bookName = bookName;
} }
- 测试方法
package site.wangxin520.gof.iterator; /**
* 迭代器模式的测试方法
* @author wangXgnaw
*
*/
public class IteratorTest {
public static void main(String[] args) {
//获得一个书柜
BookShelf bs=new BookShelf();
//往书柜里面放书
bs.putBook(new Book("红楼梦"));
bs.putBook(new Book("西游记"));
bs.putBook(new Book("三国演义"));
bs.putBook(new Book("水浒传")); //使用迭代器,依次获取到书柜中书的名字
Iterator iterator = bs.iterator();
while (iterator.hasNext()) {
Book nextBook = (Book) iterator.next();
String bookName = nextBook.getBookName();
System.out.println(bookName);
}
}
}
- 最后的结果:

设计模式之——迭代器模式的更多相关文章
- 乐在其中设计模式(C#) - 迭代器模式(Iterator Pattern)
原文:乐在其中设计模式(C#) - 迭代器模式(Iterator Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 迭代器模式(Iterator Pattern) 作者:weba ...
- Python进阶:设计模式之迭代器模式
在软件开发领域中,人们经常会用到这一个概念——“设计模式”(design pattern),它是一种针对软件设计的共性问题而提出的解决方案.在一本圣经级的书籍<设计模式:可复用面向对象软件的基础 ...
- 设计模式学习--迭代器模式(Iterator Pattern)和组合模式(Composite Pattern)
设计模式学习--迭代器模式(Iterator Pattern) 概述 ——————————————————————————————————————————————————— 迭代器模式提供一种方法顺序 ...
- js设计模式——4.迭代器模式
js设计模式——4.迭代器模式 代码演示 /*js设计模式——迭代器模式*/ class Iterator { constructor(container) { this.list = contain ...
- 实践GoF的设计模式:迭代器模式
摘要:迭代器模式主要用在访问对象集合的场景,能够向客户端隐藏集合的实现细节. 本文分享自华为云社区<[Go实现]实践GoF的23种设计模式:迭代器模式>,作者:元闰子. 简介 有时会遇到这 ...
- 【GOF23设计模式】迭代器模式
来源:http://www.bjsxt.com/ 一.[GOF23设计模式]_迭代器模式.JDK内置迭代器.内部类迭代器 package com.test.iterator; /** * 自定义的迭代 ...
- [设计模式] 16 迭代器模式 Iterator Pattern
在GOF的<设计模式:可复用面向对象软件的基础>一书中对迭代器模式是这样说的:提供一种方法顺序访问一个聚合对象中各个元素,而又不需要暴露该对象的内部表示. 类图和实例: 迭代器模式由以下角 ...
- php设计模式之迭代器模式
今天的PHP设计模式系列的主角是迭代器(Iterator)模式,迭代器模式提供了抽象:位于对象图不明部分的一组对象(或标量)集合上的迭代. 迭代器(Iterator)模式,它在一个很常见的过程上提供了 ...
- 设计模式之迭代器模式(Iterator)摘录
23种GOF设计模式一般分为三大类:创建型模式.结构型模式.行为模式. 创建型模式抽象了实例化过程,它们帮助一个系统独立于怎样创建.组合和表示它的那些对象.一个类创建型模式使用继承改变被实例化的类,而 ...
- [设计模式] Iterator - 迭代器模式:由一份奥利奥早餐联想到的设计模式
Iterator - 迭代器模式 目录 前言 回顾 UML 类图 代码分析 抽象的 UML 类图 思考 前言 这是一包奥利奥(数组),里面藏了很多块奥利奥饼干(数组中的元素),我将它们放在一个碟子上慢 ...
随机推荐
- 词法分析器总结--flex&bison
转自:项目总结之词法分析器 无论是词法分析,还是语法分析,给我的第一感觉就是逻辑要严谨.由于项目有自己一套完整的语言和语法,设计好其对应的词法分析器和语法分析器显得尤为重要. 我们采用flex进行词法 ...
- jq判断元素class是否定义了CSS样式
if($("div").attr("class")==null) 如果$("div").attr("class")为空, ...
- Excel TargetRange.Validation为空的
做Excel的时候遇到过TargetRange.Validation为空,赋值类似空指针一样的情况. 这样的情况,不懂Excel调试了好久,最后还知道,这个对象需要自己去定义才能够进行赋值, 这样定义 ...
- [debootstrap]制作基于arm平台的debian文件系统
之前用过的Linux文件系统是直接busybox制作的,而当前使用的是debian的Jessie,看了一些博客后,了解到如果使用debian,那么直接使用debootstrap来构建文件系统即可 -- ...
- Keil的使用方法(汇总)
推荐 分享一个大神的人工智能教程.零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到人工智能的队伍中来! http://www.captainbed.net/strongerhuang 软件的开发 ...
- [转]hadoop,spark,storm,pig,hive,mahout等到底有什么区别和联系?
摘自知乎大神的论述 作者:Xiaoyu Ma链接:https://www.zhihu.com/question/27974418/answer/38965760来源:知乎著作权归作者所有,转载请联系作 ...
- msyql的内存计算
本文将讨论MySQL内存相关的一些选项,包括: 单位都是b,不是kb,即1B=1/(1024*1024*1024)G 1)全局的buffer,如innodb_buffer_pool_size: 2)线 ...
- python的zipfile实现文件目录解压缩
主要是 解决了压缩目录下 空文件夹 的压缩 和 解压缩问题 压缩文件夹的函数: # coding:utf- import os import zipfile def zipdir(dirToZip,s ...
- MySQL Python教程(2)
mysql官网关于python的API是最经典的学习材料,相信对于所有函数浏览一遍以后,Mysql数据库用起来一定得心应手. 首先看一下Connector/Python API包含哪些类和模块. Mo ...
- Dubbo (开源分布式服务框架)
Provider 暴露服务方称之为“服务提供者”. Consumer 调用远程服务方称之为“服务消费者”. Registry 服务注册与发现的中心目录服务称之为“服务注册中心”. Monitor 统计 ...