GOF之迭代器模式
来源:互联网 发布:淘宝网店大师靠谱吗 编辑:程序博客网 时间:2024/06/06 08:38
迭代器模式
其实迭代器模式的话,我们经常使用。现在我们就来学习一个迭代器的底层的实现。
现在我们来学习一下迭代器的底层的实现:
package com.bjsxt.iterator;
/**
* 自定义的迭代器接口
* @author Administrator
*
*/
public interface MyIterator {
void first(); //将游标指向第一个元素
void next(); //将游标指向下一个元素
boolean hasNext();//判断是否存在下一个元素
boolean isFirst();
boolean isLast();
Object getCurrentObj(); //获取当前游标指向的对象
}
package com.bjsxt.iterator;
import java.util.ArrayList;
import java.util.List;
/**
* 自定义的聚合类
* @author Administrator
*
*/
public class ConcreteMyAggregate {
private List<Object> list = new ArrayList<Object>();
public void addObject(Object obj){
this.list.add(obj);
}
public void removeObject(Object obj){
this.list.remove(obj);
}
public List<Object> getList() {
return list;
}
public void setList(List<Object> list) {
this.list = list;
}
//获得迭代器
public MyIterator createIterator(){
return new ConcreteIterator();
}
//使用内部类定义迭代器,可以直接使用外部类的属性
private class ConcreteIterator implements MyIterator {
private int cursor; //定义游标用于记录遍历时的位置
@Override
public void first() {
cursor = 0;
}
@Override
public Object getCurrentObj() {
return list.get(cursor);
}
@Override
public boolean hasNext() {
if(cursor<list.size()){
return true;
}
return false;
}
@Override
public boolean isFirst() {
return cursor==0?true:false;
}
@Override
public boolean isLast() {
return cursor==(list.size()-1)?true:false;
}
@Override
public void next() {
if(cursor<list.size()){
cursor++;
}
}
}
}
- GOF之迭代器模式
- GOF设计模式之ITERATOR(迭代器)
- Gof之状态模式
- GOF之状态模式
- GOF之策略模式
- GOF之组合模式
- GOF之装饰模式
- GOF之外观模式
- GOF之适配器模式
- GOF 设计模式之 Command
- GOF之中介者模式
- GOF之责任链模式
- GOF之模板方法模式
- GOF之解释器模式
- GOF之享元模式
- GOF之桥接模式
- GOF之静态代理模式
- GOF之动态代理模式
- Bellovin
- C++ 引用计数技术及智能指针的简单实现及改进
- 最长公共子序列
- 如何在linux下检测内存泄漏
- [LeetCode] max-points-on-a-line
- GOF之迭代器模式
- android 16进制颜色代码
- 【解题报告】Codeforces Round #367 (Div. 2)
- Mysql函数date_format,from_unixtime 详解
- IOS网络编程之微博发说说
- 【57】二叉树的下一个结点
- 数据结构与算法简记:红黑树
- The All-purpose Zero
- hdu 2017