引言
??"革命尚未成功,同志仍需努力"。不知不覺設(shè)計(jì)模式的寫了一半了,今天我們繼續(xù),回顧上一節(jié)我們講的責(zé)任鏈模式,這節(jié)我們講一下迭代器模式。
示例地址
??Demo地址
類圖
image
定義
??提供一種方法順序訪問(wèn)一個(gè)容器對(duì)象中的各個(gè)元素,而又不需要暴露該對(duì)象的內(nèi)部表示。
使用場(chǎng)景
??遍歷一個(gè)容器對(duì)象時(shí)。
迭代器模式示例
??現(xiàn)在的社會(huì),公司收購(gòu)很正常,例如阿里收購(gòu)餓了么。很多公司的工資報(bào)表做的都是不一樣的。打個(gè)比方,有的是以數(shù)組形式存在的,有的是以集合形式存在的。但最終體現(xiàn)的都一樣,張三7月份工資30232?,F(xiàn)在我們要將這2種形式合并到一塊,我們?cè)撛趺醋觥?/p>
1. 我們先定義一個(gè)工資的Bean
/**
* 工資組成bean
*
* @author 512573717@qq.com
* @created 2018/7/20 下午4:08.
*/
public class Salary {
private String name;
private String pay;
private String month;
public Salary(String name, String pay, String month) {
this.name = name;
this.pay = pay;
this.month = month;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPay() {
return pay;
}
public void setPay(String pay) {
this.pay = pay;
}
public String getMonth() {
return month;
}
public void setMonth(String month) {
this.month = month;
}
@Override
public String toString() {
return "Salary{" +
"name='" + name + '\'' +
", pay='" + pay + '\'' +
", month='" + month + '\'' +
'}';
}
}
2. 定義迭代器接口
/**
* 迭代器接口
*
* @author 512573717@qq.com
* @created 2018/7/20 下午3:02.
*/
public interface Iterator<T> {
void first();//將游標(biāo)指向第一個(gè)元素
void next();//將游標(biāo)指向下一個(gè)元素
boolean hasNext();//判斷是否有下一個(gè)元素
T getCurrentObj();//獲取當(dāng)前對(duì)象
}
3. 自定義容器接口
/**
* 自定義容器接口
* @author 512573717@qq.com
* @created 2018/7/23 上午10:45.
*/
public interface IManager {
Iterator createIterator();
}
4. 數(shù)組迭代器的實(shí)現(xiàn)
/**
* 數(shù)組迭代器
*
* @author 512573717@qq.com
* @created 2018/7/20 下午4:17.
*/
public class ArrayIterator implements Iterator {
private ArrayManager mArrayManager;
private int cursor;//定義一個(gè)迭代器游標(biāo)
public ArrayIterator(ArrayManager arrayManager) {
mArrayManager = arrayManager;
}
@Override
public void first() {
cursor = 0;
}
@Override
public void next() {
if (cursor < mArrayManager.size()) {
cursor++;
}
}
@Override
public boolean hasNext() {
//如果游標(biāo)<list的大小,則說(shuō)明還有下一個(gè)
if (cursor < mArrayManager.size()) {
return true;
}
return false;
}
@Override
public Object getCurrentObj() {
return mArrayManager.get(cursor);//獲取當(dāng)前游標(biāo)指向的元素
}
}
5. 自定義數(shù)組
/**
* 自定義數(shù)組
*
* @author 512573717@qq.com
* @created 2018/7/20 下午4:32.
*/
public class ArrayManager implements IManager {
private Salary[] mSalaries = null;
public void setSalaries(Salary[] salaries) {
mSalaries = salaries;
}
@Override
public Iterator createIterator() {
return new ArrayIterator(this);
}
public Object get(int index) {
Object retObj = null;
if (index < mSalaries.length) {
retObj = mSalaries[index];
}
return retObj;
}
public int size() {
return this.mSalaries.length;
}
}
6. 集合迭代器的實(shí)現(xiàn)
/**
* 集合的迭代器
*
* @author 512573717@qq.com
* @created 2018/7/20 下午4:34.
*/
public class CollectionIterator implements Iterator {
private CollectionManager aggregate = null;
private int cursor;//定義一個(gè)迭代器游標(biāo)
public CollectionIterator(CollectionManager aggregate) {
this.aggregate = aggregate;
}
public void first() {
cursor = 0;
}
@Override
public void next() {
if (cursor < aggregate.size()) {
cursor++;
}
}
@Override
public boolean hasNext() {
//如果游標(biāo)<list的大小,則說(shuō)明還有下一個(gè)
if (cursor < aggregate.size()) {
return true;
}
return false;
}
@Override
public Object getCurrentObj() {
return aggregate.get(cursor);//獲取當(dāng)前游標(biāo)指向的元素
}
}
7. 自定義集合
/**
* 自定義集合類
*
* @author 512573717@qq.com
* @created 2018/7/20 下午4:37.
*/
public class CollectionManager implements IManager {
private List list = new ArrayList();
public void setList(List list) {
this.list = list;
}
@Override
public Iterator createIterator() {
return new CollectionIterator(this);
}
public Object get(int index) {
Object retObj = null;
if (index < this.list.size()) {
retObj = this.list.get(index);
}
return retObj;
}
public int size() {
return this.list.size();
}
}
8. Client調(diào)用
System.out.println("數(shù)組迭代器=======");
ArrayManager arrayManager = new ArrayManager();
Salary[] salary = new Salary[3];
salary[0] = new Salary("001", "10K", "7");
salary[1] = new Salary("002", "20K", "7");
salary[2] = new Salary("003", "30K", "7");
arrayManager.setSalaries(salary);
bianLi(arrayManager.createIterator());
System.out.println("集合迭代器=======");
CollectionManager collectionManager = new CollectionManager();
ArrayList arrayList = new ArrayList();
for (int i = 0; i < 3; i++) {
Salary salary1 = new Salary("00" + (i+1), (i + 1) * 10 + "K", "7");
arrayList.add(salary1);
}
collectionManager.setList(arrayList);
bianLi(collectionManager.createIterator());
/**
* 迭代器遍歷
*
* @param iterator
*/
private void bianLi(Iterator iterator) {
iterator.first();
while (iterator.hasNext()) {
Object object = iterator.getCurrentObj();
System.out.println(object.toString());
iterator.next();
}
}
總結(jié)
??上面將兩種不同的數(shù)據(jù)(容器),通過(guò)統(tǒng)一的訪問(wèn),返回?cái)?shù)據(jù),而不需要知道內(nèi)部怎么實(shí)現(xiàn)的,這就是迭代器模式。和我們Java JDK中的迭代器是一模一樣的有沒有。