PHP设计模式之迭代器模式Iterator实例分析【对象行(2)

5.结构

结构上可以看出,迭代器模式在客户与容器之间加入了迭代器角色。迭代器角色的加入,就可以很好的避免容器内部细节的暴露,而且也使得设计符号“单一职责原则”。

注意,在迭代器模式中,具体迭代器角色和具体容器角色是耦合在一起的——遍历算法是与容器的内部细节紧密相关的。为了使客户程序从与具体迭代器角色耦合的困境中脱离出来,避免具体迭代器角色的更换给客户程序带来的修改,迭代器模式抽象了具体迭代器角色,使得客户程序更具一般性和重用性。这被称为多态迭代

6.模式的组成

抽象迭代器(Iterator): 迭代器定义访问和遍历元素的接口。
具体迭代器(ConcreteIterator):  具体迭代器实现迭代器Iterator接口。对该聚合遍历时跟踪当前位置。
抽象聚合类(Aggregate): 聚合定义创建相应迭代器对象的接口。
具体聚合类(ConcreteAggregate): 体聚合实现创建相应迭代器的接口,该操作返回ConcreteIterator的一个适当的实例。

7.效果

•迭代器模式的作用:

1 ) 它支持以不同的方式遍历一个聚合对象 : 复杂的聚合可用多种方式进行遍历。迭代器模式使得改变遍历算法变得很容易 : 仅需用一个不同的迭代器的实例代替原先的实例即可。你也可以自己定义迭代器的子类以支持新的遍历。
2) 迭代器简化了聚合的接口 有了迭代器的遍历接口,聚合本身就不再需要类似的遍历接口了。这样就简化了聚合的接口。
3) 在同一个聚合上可以有多个遍历 每个迭代器保持它自己的遍历状态。因此你可以同时进行多个遍历。
4)在迭代器模式中,增加新的聚合类和迭代器类都很方便,无须修改原有代码,满足“开闭原则”的要求。

迭代器模式的缺点

由于迭代器模式将存储数据和遍历数据的职责分离,增加新的聚合类需要对应增加新的迭代器类,类的个数成对增加,这在一定程度上增加了系统的复杂性。

8.实现

我们直接实现spl的iterator:

<?php
 
/**
 * 具体迭代器(ConcreteIterator): 具体迭代器实现迭代器Iterator接口。对该聚合遍历时跟踪当前位置。
 */
class ConcreteIterator implements Iterator {
 protected $_key;
 protected $_collection;
 public function __construct($collection){
 $this->_collection = $collection;
 $this->_key = 0;
 }
 public function rewind(){
 $this->_key = 0;
 }
 public function valid(){
 
 return isset($this->_collection[$this->_key]);
 }
 public function key(){
 return $this->_key;
 }
 public function current(){
 return $this->_collection[$this->_key];
 }
 public function next(){
 return ++$this->_key;
 }
 
}
 
/**
 * 具体聚合类(ConcreteAggregate): 
 */
class ConcreteAggregate implements IteratorAggregate{
 protected $_arr;
 public function __construct($array){
 $this->_arr = $array;
 }
 
 public function getIterator(){
 return new  ConcreteIterator($this->_arr);
 }
}
 
$_collectionay = array(1,2,3,3,4);
$it = new ConcreteIterator($_collectionay);
foreach($it as $key=>$value){
 echo $key.':'.$value.'<br/>';
}


      

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/1851.html