以下文字部分均为本人自己的想法与总结所以未必正确;
参考
https://www.cnblogs.com/xuwendong/p/9898030.html
https://github.com/flyingalex/design-patterns-by-php/blob/master/files/chapter20.md
定义:迭代器模式提供了一种方法顺序访问一个聚合对象中的各个元素,而又无需暴露该对象的内部实现,这样既可以做到不暴露集合的内部结构,又可让外部代码透明地访问集合内部的数据
使用场景:
- 访问一个集合对象的内容而无需暴露它的内部表示
- 为遍历不同的集合结构提供一个统一的接口
优点:
- 迭代器模式使得访问一个聚合对象的内容而无需暴露它的内部表示,即迭代抽象。
- 迭代器模式为遍历不同的集合结构提供了一个统一的接口,从而支持同样的算法在不同的集合结构上进行操作
角色:
抽象容器角色(Aggregate):负责提供创建具体迭代器角色的接口,一般是一个接口,提供一个iterator()方法,例如java中的Collection接口,List接口,Set接口等。
具体容器角色(ConcreteAggregate):就是实现抽象容器的具体实现类,比如List接口的有序列表实现ArrayList,List接口的链表实现LinkedList,Set接口的哈希列表的实现HashSet等。
抽象迭代器角色(Iterator):负责定义访问和遍历元素的接口。
具体迭代器角色(ConcreteIterator):实现迭代器接口,并要记录遍历中的当前位置。
<?php
//迭代器抽象类
abstract class IteratorClass
{
abstract public function first();
abstract public function next();
abstract public function isDone();
abstract public function currentItem();
}
// 聚集抽象类
abstract class Aggregate
{
abstract function createIterator();
}
class ConcreteIterator extends IteratorClass
{
private $aggregate;
private $current = 0;
function __construct($aggregate)
{
$this->aggregate = $aggregate;
}
public function first()
{
return $this->aggregate[0];
}
public function next()
{
$ret = null;
$this->current++;
if ($this->current < count($this->aggregate))
{
$ret = $this->aggregate[$this->current];
}
return $ret;
}
public function isDone()
{
return $this->current >= count($this->aggregate);
}
public function currentItem()
{
return $this->aggregate[$this->current];
}
}
class ConcreteAggregate extends Aggregate
{
private $items = [];
public function createIterator()
{
return new ConcreteIterator($this);
}
public function count()
{
return count($this->items);
}
public function add($item)
{
array_push($this->items, $item);
}
public function items()
{
return $this->items;
}
}
//客户端代码
$a = new ConcreteAggregate();
$a->add("大鸟");
$a->add("小菜");
$a->add("行李");
$a->add("老外");
$a->add("公交内部员工");
$a->add("小偷");
$i = new ConcreteIterator($a->items());
while (!$i->isDone())
{
echo $i->currentItem()." 请买票\n";
$i->next();
}