日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

php foreach 循环 判断index 小于多少_PHP设计模式之迭代器模式 - 硬核项目经理

發布時間:2025/3/19 18 豆豆
生活随笔 收集整理的這篇文章主要介紹了 php foreach 循环 判断index 小于多少_PHP设计模式之迭代器模式 - 硬核项目经理 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一說到這個模式,就不得不提循環語句。在《大話設計模式》中,作者說道這個模式現在的學習意義更大于實際意義,這是為什么呢?當然就是被foreach這貨給整得。任何語言都有這種類似的語法可以方便快捷的對數組、對象進行遍歷,從而讓迭代器模式從高高在上的23大設計模式中的明星慢慢成為了路人。特別是我們這門PHP語言,PHP的強大之處就在于對于數組的靈活操作,本身就是hashmap的結構,自然會有各種方便的數組操作語法,而foreach也是我們最常用的語句,甚至比for還常用。

Gof類圖及解釋

GoF定義:提供一種方法順序訪問一個聚合對象中各個元素,而又不需暴露該對象的內部表示

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
  • 上述Java的內容其實是筆者在做Android開發時經常會用到的,有時數據庫的JavaBean也會出現這種數組來存儲外鍵。但在PHP中一般很少使用,因為PHP中大部分的AR對象和Java中的Bean概念還是略有不同。有興趣的同學可以了解下!

我們的手機工廠不得了,自己組裝了一條生產線,這條生產線主要是做什么的呢?成型機我們已經交給富X康來搞定了,我們這條線就是給手機刷顏色的。當我們把所有已經交貨的手機(Aggregate)放到不同的生產線后(Iterator),就會一臺一臺的幫我們刷上當前生產線的顏色,是不是很強大!!科技不止于換殼,這條線還在,我們就可以再做別的事兒,比如加點掛繩什么的,反正只要能一臺一臺的通過我就能裝上東西,你說好用不好用!!

完整代碼:

實例

實例還是圍繞著我們的短信發送來看。這一次,我們的業務需求是盡快的發一批通知短信給用戶,因為活動的時候可不等人啊。在之前我們會使用多個腳本來把用戶手機號分成多組來進行發送。現在我們可以用swoole來直接多線程的發送。所要達到的效果其實就是為了快速的把成百上千的短信發完。這個時候我們也會做一些策略,比如數據庫里是100條要送的短信,有個字段是發送狀態,一個線程正序的發,一個線程倒序的發,當正序和倒序都發送到50條的時候其實已經同步的發完這100條了,不過也有可能會有失敗的情況出現,這時,兩個線程還會繼續去發送那些上次發送不成功的信息,這樣能夠最大程度的確保發送的效率和到達率。

消息發送迭代器類圖

完整源碼:https://github.com/zhangyue0503/designpatterns-php/blob/master/07.iterator/source/iterator-msg.php

<?phpinterface 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中的Iterator接口已經為我們準備好了一套標準的Iterator模式的實現,而且(這里需要畫重點),實現這個接口的類可以用foreach來遍歷哦!

文檔:

源碼:

文檔中相關的接口都可以看看,更重要的是,PHP的SPL擴展中,也為我們準備了很多常用的迭代器封裝。要知道,面試的時候要是能說出這里面的幾個來,那面試官可是也會刮目相看的哦!

SPL迭代器:

下期看點

關注公眾號:【硬核項目經理】獲取最新文章

添加微信/QQ好友:【xiaoyuezigonggong/149844827】免費得PHP、項目管理學習資料

知乎、公眾號、抖音、頭條搜索【硬核項目經理】

B站ID:482780532

總結

以上是生活随笔為你收集整理的php foreach 循环 判断index 小于多少_PHP设计模式之迭代器模式 - 硬核项目经理的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。