本篇文章給大家帶來的內容是關于php中IteratorIterator的理解(代碼示例),有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。
php之IteratorIterator個人理解
最近有重新開始搗鼓laravel的源碼了,一年多沒用實在是忘的差不多了,每次看都會從中學到很多,不懂就趕緊查手冊。看到加載配置文件的部分(config/*.php),代碼中大量使用spl類庫和接口,今天就來扯一下IteratorIterator類,網上資料太少了,加上本人也不是怎么聰明,搞了好幾天才有點眉目,以下是對它的個人理解。
IteratorIterator簡介IteratorIterator是一個迭代器包裝器,當然它本身也是迭代器。它(假定它叫Outer)在實例化時必須傳入一個實現了Traversable接口類型的迭代器實例(假定它叫Inner),當然你可以通過Outer的getInnerIterator方法獲取到這個傳入的迭代器參數Inner。你可以通過Outer的rewind(),next(),valid(),html' target='_blank'>current()和key()方法對內部迭代器Inner進行處理。
重點理解在遍歷Outer的過程中,Outer只是將rewind(),next(),valid(),current()和key()的任何調用轉發給內部迭代器Inner。
Outer可以對轉發返回的結果進行包裝,但這并不會對Inner產生任何影響。
代碼演示?phpnamespace young;class InnerIterator implements Iterator{ private $dates; private $position; public function __construct($dates = []) $this- dates = $dates; $this- position = 0; public function rewind() echo call . __METHOD__ . br reset($this- dates); public function valid() echo call . __METHOD__ . br if ($this- position = count($this- dates)) { # code... return false; return true; public function current() echo call . __METHOD__ . br return $this- dates[$this- position]; public function key() echo call . __METHOD__ . br return $this- position; public function next() echo call . __METHOD__ . br ++$this- position; }}class OuterIterator extends IteratorIterator{ function rewind() echo __METHOD__ . br return parent::rewind(); function valid() echo __METHOD__ . br return parent::valid(); function current() echo __METHOD__ . br return parent::current() . _suffix function key() echo __METHOD__ . br return parent::key() ; function next() echo __METHOD__ . br return parent::next() ; function getInnerIterator() echo __METHOD__ . br return parent::getInnerIterator(); }}$tmpArr = array( 2018-10-01 , 2018-10-02 , // 2018-10-03 $inner = new InnerIterator($tmpArr);$outer = new OuterIterator($inner);foreach ($outer as $key = $value) { # code... echo $key , = , $value . hr }運行結果:
youngOuterIterator::rewind
call youngInnerIterator::rewindcall youngInnerIterator::validcall youngInnerIterator::currentcall youngInnerIterator::key
youngOuterIterator::validyoungOuterIterator::currentyoungOuterIterator::key0= 2018-10-01_suffixyoungOuterIterator::next
call youngInnerIterator::nextcall youngInnerIterator::validcall youngInnerIterator::currentcall youngInnerIterator::key
youngOuterIterator::validyoungOuterIterator::currentyoungOuterIterator::key1= 2018-10-02_suffixyoungOuterIterator::next
call youngInnerIterator::nextcall youngInnerIterator::valid
youngOuterIterator::valid object(youngInnerIterator)#1 (2) { [“dates”:“youngInnerIterator”:private]= array(2) { [0]= string(10) “2018-10-01” [1]= string(10) “2018-10-02” } [“position”:“youngInnerIterator”:private]= int(2) }結果分析
Outer的每次迭代會先調用自己的方法,然后轉發給Inner。
Outer內部方法的返回值都是基于Inner的相對于方法的返回。
你可以在Outer內方法對Inner的返回值做邏輯處理。
當Inner的valid返回false的時候,外層的Outer也將停止迭代。
Outer內的方法對返回值的修改并不會影響Inner。
Outer內的方法在迭代過程中并不會執行getInnerIterator方法,它只是一個獲取Inner方法的調用接口。
之前在網上翻閱資料時會看到這樣的疑惑
//假如這里還是使用了上面的兩個類代碼 ?phpnamespace young;class InnerIterator implements Iterator //code 這里的代碼假如和上面的一樣class OuterIterator extends IteratorIterator //code 這里的代碼假如和上面的一樣$outer- valid(); //false$outer- current(); // _suffix 問題一$outer- rewind(); $outer- valid(); //true$outer- current(); //2018-10-01_suffix$outer- next()$outer- rewind();$outer- current(); //2018-10-02_suffix 問題二
這里有兩個問題,
問題一,為什么當前current沒值,valid為false
問題二,問什么next后rewind之后,current是第二個值
從上面的運行結果可知,$outer不執行rewind,$inner也不會執行,所以valid返回false,current為null,_suffix只是自己拼接上的。
第二個問題也是很奇怪的,也是剛剛發現的,$inner的指針只要前進了,就回不去了,也就是說 $inner的position屬性在第一次next之后變成1了,即使你rewind,position還是1,這個有點蒙蔽啊。。。
所以如果你進行了$outer的遍歷操作,第二遍是沒值輸出的,即使第二遍也執行了rewind操作,但是這個操作在第二遍壓根就沒用~~~
以上就是對php中IteratorIterator的理解(代碼示例)的詳細內容,PHP教程
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。
新聞熱點
疑難解答