您好,登錄后才能下訂單哦!
這篇文章給大家介紹如何在PHP中使用迭代器模式,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
php的框架:1、Laravel,Laravel是一款免費并且開源的PHP應用框架。2、Phalcon,Phalcon是運行速度最快的一個PHP框架。3、Symfony,Symfony是一款為Web項目準備的PHP框架。4、Yii,Yii是一款快速、安全和專業的PHP框架。5、CodeIgniter,CodeIgniter是一款非常敏捷的開源PHP框架。6、CakePHP,CakePHP是一款老牌的PHP框架。7.Kohana,Kohana是一款敏捷但是功能強大的PHP框架。
GoF定義:提供一種方法順序訪問一個聚合對象中各個元素,而又不需暴露該對象的內部表示
代碼實現
interface Aggregate { public function CreateIterator(); } class ConcreteAggregate implements Aggregate { public function CreateIterator() { $list = [ "a", "b", "c", "d", ]; return new ConcreteIterator($list); } }
首先是聚合類,也就是可以進行迭代的類,這里因為我是面向對象的設計模式,所以迭代器模式針對的是對一個類的內容進行迭代。在這里,其實我們也只是模擬了一個數組交給了迭代器。
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]; } }
迭代器閃亮登場,主要實現了四個方法來對集合數據進行操作。有點像學習數據結構或數據庫時對游標進行的操作。用First()和Next()來移動游標,用CurrentItem()來獲得當前游標的數據內容,用IsDone()來確認是否還有下一條數據。所以,這個模式也另稱為游標模式。
$agreegate = new ConcreteAggregate(); $iterator = $agreegate->CreateIterator(); while (!$iterator->IsDone()) { echo $iterator->CurrentItem(), PHP_EOL; $iterator->Next(); }
客戶端直接使用while來進行操作即可。
大家一定很好奇,為什么我們的迭代器接口類不用Iterator來命名?試試就知道,PHP為我們準備好了一個這個接口,實現之后就可以用foreach來使用這個實現了Iterator接口的類了,是不是很高大上。我們最后再看這個類的使用。
不是說好對類進行遍歷嗎?為啥來回傳遞一個數組?開發過Java的同學一定知道,在一個名為Object類的JavaBean中,會寫一個變量List類型的變量如List myList,用來表示當前對象的集合。在使用的時候給這個List添加數據后,下次就可以直接用Object.myList來獲得一組數據了。比如從接口中獲得的json數組內容就可以這樣存在一個Bean中。這時,我們使用迭代器就可以只針對自己這個對象內部的這個數組來進行操作啦!
上述Java的內容其實是筆者在做Android開發時經常會用到的,有時數據庫的JavaBean也會出現這種數組來存儲外鍵。但在PHP中一般很少使用,因為PHP中大部分的AR對象和Java中的Bean概念還是略有不同。有興趣的同學可以了解下!
我們的手機工廠不得了,自己組裝了一條生產線,這條生產線主要是做什么的呢?成型機我們已經交給富X康來搞定了,我們這條線就是給手機刷顏色的。當我們把所有已經交貨的手機(Aggregate)放到不同的生產線后(Iterator),就會一臺一臺的幫我們刷上當前生產線的顏色,是不是很強大!!科技不止于換殼,這條線還在,我們就可以再做別的事兒,比如加點掛繩什么的,反正只要能一臺一臺的通過我就能裝上東西,你說好用不好用!!
完整代碼:github.com/zhangyue050…
實例還是圍繞著我們的短信發送來看。這一次,我們的業務需求是盡快的發一批通知短信給用戶,因為活動的時候可不等人啊。在之前我們會使用多個腳本來把用戶手機號分成多組來進行發送。現在我們可以用swoole來直接多線程的發送。所要達到的效果其實就是為了快速的把成百上千的短信發完。這個時候我們也會做一些策略,比如數據庫里是100條要送的短信,有個字段是發送狀態,一個線程正序的發,一個線程倒序的發,當正序和倒序都發送到50條的時候其實已經同步的發完這100條了,不過也有可能會有失敗的情況出現,這時,兩個線程還會繼續去發送那些上次發送不成功的信息,這樣能夠最大程度的確保發送的效率和到達率。
消息發送迭代器類圖
完整源碼:github.com/zhangyue050…
<?php interface MsgIterator { public function First(); public function Next(); public function IsDone(); public function CurrentItem(); } // 正向迭代器 class MsgIteratorAsc implements MsgIterator { 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]; } } // 反向迭代器 class MsgIteratorDesc implements MsgIterator { private $list; private $index; public function __construct($list) { // 反轉數組 $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); } } // 要發的短信號碼列表 $mobileList = [ '13111111111', '13111111112', '13111111113', '13111111114', '13111111115', '13111111116', '13111111117', '13111111118', ]; // A服務器腳本或使用swoole發送正向的一半 $serverA = new MessageAsc(); $iteratorA = $serverA->CreateIterator($mobileList); while (!$iteratorA->IsDone()) { echo $iteratorA->CurrentItem(), PHP_EOL; $iteratorA->Next(); } // B服務器腳本或使用swoole同步發送反向的一半 $serverB = new MessageDesc(); $iteratorB = $serverB->CreateIterator($mobileList); while (!$iteratorB->IsDone()) { echo $iteratorB->CurrentItem(), PHP_EOL; $iteratorB->Next(); }
說明
其實就是兩個迭代器,一個是正序一個是倒序,然后遍歷數組
例子中我們還是對一個數組的操作,另外用兩個類似于工廠方法模式的類來對迭代器進行封裝
例子非常簡單,但有時候這種用法也非常實用,比如一些搜索引擎排名的爬蟲,多次確認某些關鍵詞的排名,這時候我們就可以正著、反著來回進行驗證
關于如何在PHP中使用迭代器模式就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。