小編給大家分享一下PHP中中迭代器模式是什么,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
創(chuàng)新互聯(lián)是專(zhuān)業(yè)的淄川網(wǎng)站建設(shè)公司,淄川接單;提供成都網(wǎng)站建設(shè)、網(wǎng)站制作,網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專(zhuān)業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行淄川網(wǎng)站開(kāi)發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專(zhuān)業(yè)做搜索引擎喜愛(ài)的網(wǎng)站,專(zhuān)業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!
一說(shuō)到這個(gè)模式,就不得不提循環(huán)語(yǔ)句。在《大話(huà)設(shè)計(jì)模式》中,作者說(shuō)道這個(gè)模式現(xiàn)在的學(xué)習(xí)意義更大于實(shí)際意義,這是為什么呢?當(dāng)然就是被foreach這貨給整得。任何語(yǔ)言都有這種類(lèi)似的語(yǔ)法可以方便快捷的對(duì)數(shù)組、對(duì)象進(jìn)行遍歷,從而讓迭代器模式從高高在上的23大設(shè)計(jì)模式中的明星慢慢成為了路人。特別是我們這門(mén)PHP語(yǔ)言,PHP的強(qiáng)大之處就在于對(duì)于數(shù)組的靈活操作,本身就是hashmap的結(jié)構(gòu),自然會(huì)有各種方便的數(shù)組操作語(yǔ)法,而foreach也是我們最常用的語(yǔ)句,甚至比f(wàn)or還常用。
GoF定義:提供一種方法順序訪(fǎng)問(wèn)一個(gè)聚合對(duì)象中各個(gè)元素,而又不需暴露該對(duì)象的內(nèi)部表示
GoF類(lèi)圖
代碼實(shí)現(xiàn)
interface Aggregate { public function CreateIterator(); } class ConcreteAggregate implements Aggregate { public function CreateIterator() { $list = [ "a", "b", "c", "d", ]; return new ConcreteIterator($list); } }
首先是聚合類(lèi),也就是可以進(jìn)行迭代的類(lèi),這里因?yàn)槲沂敲嫦驅(qū)ο蟮脑O(shè)計(jì)模式,所以迭代器模式針對(duì)的是對(duì)一個(gè)類(lèi)的內(nèi)容進(jìn)行迭代。在這里,其實(shí)我們也只是模擬了一個(gè)數(shù)組交給了迭代器。
interface MyIterator { public function First(); public function Next(); public function IsDone(); public function CurrentItem(); } class ConcreteIterator implements MyIterator { private $list; private $index; public function __construct($list) { $this->list = $list; $this->index = 0; } public function First() { $this->index = 0; } public function Next() { $this->index++; } public function IsDone() { return $this->index >= count($this->list); } public function CurrentItem() { return $this->list[$this->index]; } }
迭代器閃亮登場(chǎng),主要實(shí)現(xiàn)了四個(gè)方法來(lái)對(duì)集合數(shù)據(jù)進(jìn)行操作。有點(diǎn)像學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)或數(shù)據(jù)庫(kù)時(shí)對(duì)游標(biāo)進(jìn)行的操作。用First()和Next()來(lái)移動(dòng)游標(biāo),用CurrentItem()來(lái)獲得當(dāng)前游標(biāo)的數(shù)據(jù)內(nèi)容,用IsDone()來(lái)確認(rèn)是否還有下一條數(shù)據(jù)。所以,這個(gè)模式也另稱(chēng)為游標(biāo)模式。
$agreegate = new ConcreteAggregate(); $iterator = $agreegate->CreateIterator(); while (!$iterator->IsDone()) { echo $iterator->CurrentItem(), PHP_EOL; $iterator->Next(); }
客戶(hù)端直接使用while來(lái)進(jìn)行操作即可。
大家一定很好奇,為什么我們的迭代器接口類(lèi)不用Iterator來(lái)命名?試試就知道,PHP為我們準(zhǔn)備好了一個(gè)這個(gè)接口,實(shí)現(xiàn)之后就可以用foreach來(lái)使用這個(gè)實(shí)現(xiàn)了Iterator接口的類(lèi)了,是不是很高大上。我們最后再看這個(gè)類(lèi)的使用。
不是說(shuō)好對(duì)類(lèi)進(jìn)行遍歷嗎?為啥來(lái)回傳遞一個(gè)數(shù)組?開(kāi)發(fā)過(guò)Java的同學(xué)一定知道,在一個(gè)名為Object類(lèi)的JavaBean中,會(huì)寫(xiě)一個(gè)變量List類(lèi)型的變量如List myList,用來(lái)表示當(dāng)前對(duì)象的集合。在使用的時(shí)候給這個(gè)List添加數(shù)據(jù)后,下次就可以直接用Object.myList來(lái)獲得一組數(shù)據(jù)了。比如從接口中獲得的json數(shù)組內(nèi)容就可以這樣存在一個(gè)Bean中。這時(shí),我們使用迭代器就可以只針對(duì)自己這個(gè)對(duì)象內(nèi)部的這個(gè)數(shù)組來(lái)進(jìn)行操作啦!
上述Java的內(nèi)容其實(shí)是筆者在做Android開(kāi)發(fā)時(shí)經(jīng)常會(huì)用到的,有時(shí)數(shù)據(jù)庫(kù)的JavaBean也會(huì)出現(xiàn)這種數(shù)組來(lái)存儲(chǔ)外鍵。但在PHP中一般很少使用,因?yàn)镻HP中大部分的AR對(duì)象和Java中的Bean概念還是略有不同。有興趣的同學(xué)可以了解下!
我們的手機(jī)工廠(chǎng)不得了,自己組裝了一條生產(chǎn)線(xiàn),這條生產(chǎn)線(xiàn)主要是做什么的呢?成型機(jī)我們已經(jīng)交給富X康來(lái)搞定了,我們這條線(xiàn)就是給手機(jī)刷顏色的。當(dāng)我們把所有已經(jīng)交貨的手機(jī)(Aggregate)放到不同的生產(chǎn)線(xiàn)后(Iterator),就會(huì)一臺(tái)一臺(tái)的幫我們刷上當(dāng)前生產(chǎn)線(xiàn)的顏色,是不是很強(qiáng)大??!科技不止于換殼,這條線(xiàn)還在,我們就可以再做別的事兒,比如加點(diǎn)掛繩什么的,反正只要能一臺(tái)一臺(tái)的通過(guò)我就能裝上東西,你說(shuō)好用不好用?。?/em>
完整代碼:https://github.com/zhangyue0503/designpatterns-php/blob/master/07.iterator/source/iterator.php
實(shí)例還是圍繞著我們的短信發(fā)送來(lái)看。這一次,我們的業(yè)務(wù)需求是盡快的發(fā)一批通知短信給用戶(hù),因?yàn)榛顒?dòng)的時(shí)候可不等人啊。在之前我們會(huì)使用多個(gè)腳本來(lái)把用戶(hù)手機(jī)號(hào)分成多組來(lái)進(jìn)行發(fā)送。現(xiàn)在我們可以用swoole來(lái)直接多線(xiàn)程的發(fā)送。所要達(dá)到的效果其實(shí)就是為了快速的把成百上千的短信發(fā)完。這個(gè)時(shí)候我們也會(huì)做一些策略,比如數(shù)據(jù)庫(kù)里是100條要送的短信,有個(gè)字段是發(fā)送狀態(tài),一個(gè)線(xiàn)程正序的發(fā),一個(gè)線(xiàn)程倒序的發(fā),當(dāng)正序和倒序都發(fā)送到50條的時(shí)候其實(shí)已經(jīng)同步的發(fā)完這100條了,不過(guò)也有可能會(huì)有失敗的情況出現(xiàn),這時(shí),兩個(gè)線(xiàn)程還會(huì)繼續(xù)去發(fā)送那些上次發(fā)送不成功的信息,這樣能夠最大程度的確保發(fā)送的效率和到達(dá)率。
消息發(fā)送迭代器類(lèi)圖
完整源碼:https://github.com/zhangyue0503/designpatterns-php/blob/master/07.iterator/source/iterator-msg.php
list = $list; $this->index = 0; } public function First() { $this->index = 0; } public function Next() { $this->index++; } public function IsDone() { return $this->index >= count($this->list); } public function CurrentItem() { return $this->list[$this->index]; } } // 反向迭代器 class MsgIteratorDesc implements MsgIterator { private $list; private $index; public function __construct($list) { // 反轉(zhuǎn)數(shù)組 $this->list = array_reverse($list); $this->index = 0; } public function First() { $this->index = 0; } public function Next() { $this->index++; } public function IsDone() { return $this->index >= count($this->list); } public function CurrentItem() { return $this->list[$this->index]; } } interface Message { public function CreateIterator($list); } class MessageAsc implements Message { public function CreateIterator($list) { return new MsgIteratorAsc($list); } } class MessageDesc implements Message { public function CreateIterator($list) { return new MsgIteratorDesc($list); } } // 要發(fā)的短信號(hào)碼列表 $mobileList = [ '13111111111', '13111111112', '13111111113', '13111111114', '13111111115', '13111111116', '13111111117', '13111111118', ]; // A服務(wù)器腳本或使用swoole發(fā)送正向的一半 $serverA = new MessageAsc(); $iteratorA = $serverA->CreateIterator($mobileList); while (!$iteratorA->IsDone()) { echo $iteratorA->CurrentItem(), PHP_EOL; $iteratorA->Next(); } // B服務(wù)器腳本或使用swoole同步發(fā)送反向的一半 $serverB = new MessageDesc(); $iteratorB = $serverB->CreateIterator($mobileList); while (!$iteratorB->IsDone()) { echo $iteratorB->CurrentItem(), PHP_EOL; $iteratorB->Next(); }
說(shuō)明
其實(shí)就是兩個(gè)迭代器,一個(gè)是正序一個(gè)是倒序,然后遍歷數(shù)組
例子中我們還是對(duì)一個(gè)數(shù)組的操作,另外用兩個(gè)類(lèi)似于工廠(chǎng)方法模式的類(lèi)來(lái)對(duì)迭代器進(jìn)行封裝
例子非常簡(jiǎn)單,但有時(shí)候這種用法也非常實(shí)用,比如一些搜索引擎排名的爬蟲(chóng),多次確認(rèn)某些關(guān)鍵詞的排名,這時(shí)候我們就可以正著、反著來(lái)回進(jìn)行驗(yàn)證
看完了這篇文章,相信你對(duì)“PHP中中迭代器模式是什么”有了一定的了解,如果想了解更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!