当前位置:首页 > PHP教程 > php应用 > 列表

PHP设计模式之PHP迭代器模式讲解

发布:smiling 来源: PHP粉丝网  添加日期:2021-11-13 23:28:13 浏览: 评论:0 

今天小编就为大家分享一篇关于PHP设计模式之PHP迭代器模式讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧。

迭代器有时又称光标(cursor)是程式设计的软件设计模式,可在容器物件(container,例如list或vector)上遍访的接口,设计人员无需关心容器物件的内容。

各种语言实作Iterator的方式皆不尽同,有些面向对象语言像Java, C#, Python, Delphi都已将Iterator的特性内建语言当中,完美的跟语言整合,我们称之隐式迭代器(implicit iterator),但像是C++语言本身就没有Iterator的特色,但STL仍利用template实作了功能强大的iterator。

PHP5开始支持了接口, 并且内置了Iterator接口, 所以如果你定义了一个类,并实现了Iterator接口,那么你的这个类对象就是ZEND_ITER_OBJECT,否则就是ZEND_ITER_PLAIN_OBJECT.

对于ZEND_ITER_PLAIN_OBJECT的类,foreach会通过HASH_OF获取该对象的默认属性数组,然后对该数组进行foreach.

先来看下迭代器的定义,那就是提供一种方法顺序访问一个聚合对象中各个元素,而又不暴露该对象的内部显示。它可帮助构造特定的对象,那些对象能够提供单一标准接口循环或迭代任何类型的可计数数据。来看下迭代器模式的结构图:

再来看下迭代器需要用到的内部方法:

Iterator::current — Return the current element 返回当前元素

Iterator::key — Return the key of the current element 返回当前元素的键

Iterator::next — Move forward to next element 移向下一个元素

Iterator::rewind — Rewind the Iterator to the first element 重新回到第一个元素

Iterator::valid — Checks if current position is valid 检查当前位置的有效性

而对于ZEND_ITER_OBJECT的类对象,则会通过调用对象实现的Iterator接口相关函数来进行foreach。

  1. <?php 
  2. /** 
  3. * Iterator模式的简单实现类 
  4. */ 
  5. class sample implements Iterator { 
  6.   private $_items ; 
  7.   public function __construct(&$data) { 
  8.     $this->_items = $data
  9.   } 
  10.   public function current() { 
  11.     return current($this->_items); 
  12.   } 
  13.   public function next() { 
  14.     next($this->_items);   
  15.   } 
  16.   public function key() { 
  17.     return key($this->_items); 
  18.   } 
  19.   public function rewind() { 
  20.     reset($this->_items); 
  21.   } 
  22.   public function valid() {                                        
  23.     return ($this->current() !== FALSE); 
  24.   } 
  25. /** DEMO */ 
  26. $data = array(1, 2, 3, 4, 5); 
  27. $sa = new sample($data); 
  28. foreach ($sa AS $key => $row) { 
  29.   echo $key' '$row'<br />'
  30. ?> 

举几个迭代器的使用范围:

使用返回迭代器的包或库时(如PHP5中的SPL迭代器)

无法在一次的调用获取容器的所有元素时

要处理数量巨大的无素时(数据库中的表以GB计的数据)

……

不同的迭代器有不同的接口,例如PHP SPL迭代器中包括Next()(移动到下一个元素),corrent()(返回当前元素),valid()(检查迭代结尾),rewind()(从头重新开始),key()(返回当前元素的索引)。当然你可以自己写适合自己用的迭代器,也可以用系统中的迭代器。

一般是使用foreach来使用迭代器,下面整理了一下代码:

  1. <?php   
  2. class sample implements Iterator 
  3.   private $_items = array(1,2,3,4,5,6,7); 
  4.   public function __construct() { 
  5.          ;//void 
  6.   } 
  7.   public function rewind() { reset($this->_items); } 
  8.   public function current() { return current($this->_items); } 
  9.   public function key() { return key($this->_items); } 
  10.   public function next() { return next($this->_items); } 
  11.   public function valid() { return ( $this->current() !== false ); } 
  12. $sa = new sample(); 
  13. foreach($sa as $key => $val){ 
  14.   print $key . "=>" .$val
  15. ?> 

while循环也可以:

  1. <?php 
  2. while ($itertor->valid()){ //判断是不是最后元素 
  3.  $element=$itertor->current(); //获取当前元素 
  4.  $itertor->next(); //移动到下一个元素 
  5. ?> 

为什么要学习PHP的迭代器呢?有个很重要的原因:利用PHP的迭代器可以利用面向对象实现常见的数据结构,例如列表,堆栈,队列与图。后面会做一个专题,用PHP实现大部分的数据结构,而且以面向对象的形式,所以这里先预热了一下PHP的迭代器。

Tags: PHP设计模式 PHP迭代器

分享到: