php聚合式迭代器的基礎(chǔ)知識(shí)點(diǎn)及實(shí)例代碼
1、實(shí)現(xiàn)其他迭代器功能的接口,相當(dāng)于在其他迭代器上安裝一個(gè)外殼,只有一種方法。
2、聚合迭代器可以與許多迭代器結(jié)合,實(shí)現(xiàn)更高效的迭代。
實(shí)例class MainIterator implements Iterator{ private $var = array(); public function __construct($array) //構(gòu)造函數(shù), 初始化對(duì)象數(shù)組 {if (is_array($array)) {$this->var = $array;} } public function rewind() { echo 'rewindingn';reset($this->var); //將數(shù)組的內(nèi)部指針指向第一個(gè)單元 } public function current() {$var = current($this->var); // 返回?cái)?shù)組中的當(dāng)前值echo 'current: $varn';return $var; } public function key() {$var = key($this->var); //返回?cái)?shù)組中內(nèi)部指針指向的當(dāng)前單元的鍵名echo 'key: $varn';return $var; } public function next() {$var = next($this->var); //返回?cái)?shù)組內(nèi)部指針指向的下一個(gè)單元的值echo 'next: $varn';return $var; } public function valid() { return !is_null(key($this->var); //判斷當(dāng)前單元的鍵是否為空 }}
內(nèi)容擴(kuò)展:
<?phpclass myData implements IteratorAggregate { public $property1 = 'Public property one'; public $property2 = 'Public property two'; public $property3 = 'Public property three'; public function __construct() {$this->property4 = 'last property'; } public function getIterator() {return new ArrayIterator($this); }}$obj = new myData;foreach($obj as $key => $value) { var_dump($key, $value); echo 'n';}?>
以上例程的輸出類似于:
string(9) 'property1'string(19) 'Public property one'
string(9) 'property2'string(19) 'Public property two'
string(9) 'property3'string(21) 'Public property three'
string(9) 'property4'string(13) 'last property'
到此這篇關(guān)于php聚合式迭代器的基礎(chǔ)知識(shí)點(diǎn)及實(shí)例代碼的文章就介紹到這了,更多相關(guān)php聚合式迭代器是什么內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. moment轉(zhuǎn)化時(shí)間戳出現(xiàn)Invalid Date的問題及解決2. python爬蟲實(shí)戰(zhàn)之制作屬于自己的一個(gè)IP代理模塊3. 如何在jsp界面中插入圖片4. ajax請(qǐng)求后臺(tái)得到j(luò)son數(shù)據(jù)后動(dòng)態(tài)生成樹形下拉框的方法5. HTML 絕對(duì)路徑與相對(duì)路徑概念詳細(xì)6. WML的簡(jiǎn)單例子及編輯、測(cè)試方法第1/2頁(yè)7. 解決ajax請(qǐng)求后臺(tái),有時(shí)收不到返回值的問題8. asp批量添加修改刪除操作示例代碼9. .NET6打包部署到Windows Service的全過程10. 詳解盒子端CSS動(dòng)畫性能提升
