歡迎您光臨本站 註冊首頁

在維基百科中我們可以看到其定義如下:
迭代器有時又稱游標(cursor)是程式設計的軟體設計模式,可在容器物件(container,例如list或vector)上遍訪的介面,設計人員無需關心容器物件的內容。
各種語言實作Iterator的方式皆不盡同,有些面嚮物件語言像Java, C#, Python, Delphi都已將Iterator的特性內建語言當中,完美的跟語言整合,我們稱之隱式迭代器(implicit iterator),但像是C++語言本身就沒有Iterator的特色,但STL仍利用template實作了功能強大的iterator。
Iterator另一方面還可以整合Generator。有些語言將二者視為同一介面,有些語言則將之獨立化。
地址:http://zh.wikipedia.org/zh-cn/%E8%BF%AD%E4%BB%A3%E5%99%A8
【Iterator的簡單實現】
/** * Iterator模式的簡單實現類 */ class sample implements Iterator { private $_items ; public function __construct(&$data) { $this->_items = $data; } public function current() { return current($this->_items); } public function next() { next($this->_items); } public function key() { return key($this->_items); } public function rewind() { reset($this->_items); } public function valid() { return ($this->current() !== FALSE); } } /** DEMO */ $data = array(1, 2, 3, 4, 5); $sa = new sample($data); foreach ($sa AS $key => $row) { echo $key, ' ', $row, '
'; }
在next()方法的實現時有過糾結,一直以為這裡需要返回下一個的值,
這是因為一直以為這裡的next就是next函式的實現,但是非也
在手冊中我們可以看到其定義為
abstract public void Iterator::next ( void )
其返回值型別為void
所以這裡我們呼叫next函式就可以了,沒有必要返回
另外,以上實現對於如下的陣列是存在的問題
$data = array('0' => 11, "" => 22, 's3' => 33, 0, 0, "", false, 0, 1);
執行結果是輸出:
0 11
22
s3 33
1 0
2 0
3
false後面的值就沒有迭代顯示出來了,具體原因還不清楚,留作下回分解
在yii框架中也有實現迭代器,它的實現避免了這個問題。
【Yii框架中的迭代器實現】
在Yii框架中的我們可以看到其迭代器的實現
在collections目錄下的CMapIterator.php檔案中,其實現如下:
class CMapIterator implements Iterator { /** * @var array the data to be iterated through */ private $_d; /** * @var array list of keys in the map */ private $_keys; /** * @var mixed current key */ private $_key; /** * Constructor. * @param array the data to be iterated through */ public function __construct(&$data) { $this->_d=&$data; $this->_keys=array_keys($data); } /** * Rewinds internal array pointer. * This method is required by the interface Iterator. */ public function rewind() { $this->_key=reset($this->_keys); } /** * Returns the key of the current array element. * This method is required by the interface Iterator. * @return mixed the key of the current array element */ public function key() { return $this->_key; } /** * Returns the current array element. * This method is required by the interface Iterator. * @return mixed the current array element */ public function current() { return $this->_d[$this->_key]; } /** * Moves the internal pointer to the next array element. * This method is required by the interface Iterator. */ public function next() { $this->_key=next($this->_keys); } /** * Returns whether there is an element at current position. * This method is required by the interface Iterator. * @return boolean */ public function valid() { return $this->_key!==false; } } $data = array('s1' => 11, 's2' => 22, 's3' => 33); $it = new CMapIterator($data); foreach ($it as $row) { echo $row, '
'; }
這與之前的簡單實現相比,其位置的變化是透過控制key來實現的,這種實現的作用是為了避免false作為陣列值時無法迭代


[qp18502452 ] PHP中迭代器的簡單實現及Yii框架中的迭代器實現方法示例已經有207次圍觀

http://coctec.com/docs/php/show-post-232635.html