• 技术文章 >php教程 >php手册

    PHP设计模式之迭代器模式(Iterator)

    2016-06-06 20:01:21原创650

    迭代器模式为聚合对象的元素提供一种顺序访问的方式,又能让访问者不必关心聚合对象内部的内部实现。实际上我们平常使用最多的数组foreach操作就是在使用迭代器(注意:迭代器并不等于迭代器模式)。从PHP 5.3开始,PHP开始内置了Iterator接口,为我们实现迭

    迭代器模式为聚合对象的元素提供一种顺序访问的方式,又能让访问者不必关心聚合对象内部的内部实现。实际上我们平常使用最多的数组foreach操作就是在使用迭代器(注意:迭代器并不等于迭代器模式)。从PHP 5.3开始,PHP开始内置了Iterator接口,为我们实现迭代器模式提供了便利:


    //PHP5提供的Iterator接口,Traversable接口只是为了标识对象是否可以通过foreach迭代,不包含任何方法
    Iterator extends Traversable {
        /* Methods */
        abstract public mixed current ( void )
        abstract public scalar key ( void )
        abstract public void next ( void )
        abstract public void rewind ( void )
        abstract public boolean valid ( void )
    }

    也许你会觉得很奇怪(或多余),对于PHP来说,数组本身就是支持迭代的,我们为什么还要通过迭代器模式多封装一层呢?这就是模式定义的核心所在了:让访问者不必关心聚合对象的内部实现(比如元素数量、KEY、具体结构等);相对来说就是让聚合对象的内部实现不暴露给访问者(例如避免对象被访问者修改)。

    实现我们自己的迭代器:

    class RecordIterator implements Iterator{
        private $position = 0;
    
        //注意:被迭代对象属性是私有的
        private $records = array();  
    
        public function __construct(Array $records) {
            $this->position = 0;
            $this->records = $records;
        }
    
        function rewind() {
            $this->position = 0;
        }
    
        function current() {
            return $this->records[$this->position];
        }
    
        function key() {
            return $this->position;
        }
    
        function next() {
            ++$this->position;
        }
    
        function valid() {
            return isset($this->records[$this->position]);
        }
    }
    
    //假如我们从MongoDB中读取得到下列数据
    $data = array(
        0 => array('field' => 'value'),
        1 => array('field' => 'value'),
        2 => array('field' => 'value'),
        3 => array('field' => 'value'),
    );
    
    //使用我们自己定义的迭代器
    $records = new RecordIterator($data);
    while($records->valid()){
        print_r($records->current());
        $records->next();
    }
    $records->rewind();

    在GoF定义的迭代器模式中,还有两个参与者:容器和具体容器,负责初始化并返回具体的迭代器。


    //容器
    interface Aggregate
    {
        public getIterator();
    }
    
    //具体容器
    class RecordList implements Aggregate{
        private $iterator;
    
        public function __construct($data){
            $this->iterator = new RecordIterator($data);
        }
    
        public function getIterator(){
            return $this->iterator;
        }
    }
    
    //使用
    //假如我们从MongoDB中读取得到下列数据
    $data = array(
        0 => array('field' => 'value'),
        1 => array('field' => 'value'),
        2 => array('field' => 'value'),
        3 => array('field' => 'value'),
    );
    $recordList = new RecordList($data);
    $iterator = $recordList->getIterator();
    while($iterator->valid()){
        print_r($iterator->current());
        $iterator->next();
    }
    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    上一篇:Hastable 用法及循环读取 下一篇:javascript 小写数字转换为汉字大写数字
    PHP编程就业班

    相关文章推荐

    • php判断当前用户已在别处登录的方法,当前用户在别处• SSI使用详解(二)• 在WAS CE上运行PHP• 解析:通过php socket并借助telnet实现简单的聊天程序• php (十四) 面向对象 魔术方法 __set()、__get()、__isset() 与 __unset()

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网