主頁(yè) > 知識(shí)庫(kù) > PHP設(shè)計(jì)模式之PHP迭代器模式講解

PHP設(shè)計(jì)模式之PHP迭代器模式講解

熱門標(biāo)簽:九江外呼系統(tǒng) 地下城堡2圖九地圖標(biāo)注 抖音有個(gè)地圖標(biāo)注是什么意思 阿里云400電話申請(qǐng)加工單 保定crm外呼系統(tǒng)運(yùn)營(yíng)商 七魚(yú)外呼系統(tǒng)停用嗎 西區(qū)企業(yè)怎么做地圖標(biāo)注入駐 智能電話機(jī)器人排名前十名南京 海南人工外呼系統(tǒng)有效果嗎

迭代器有時(shí)又稱光標(biāo)(cursor)是程式設(shè)計(jì)的軟件設(shè)計(jì)模式,可在容器物件(container,例如list或vector)上遍訪的接口,設(shè)計(jì)人員無(wú)需關(guān)心容器物件的內(nèi)容。

各種語(yǔ)言實(shí)作Iterator的方式皆不盡同,有些面向?qū)ο笳Z(yǔ)言像Java, C#, Python, Delphi都已將Iterator的特性內(nèi)建語(yǔ)言當(dāng)中,完美的跟語(yǔ)言整合,我們稱之隱式迭代器(implicit iterator),但像是C++語(yǔ)言本身就沒(méi)有Iterator的特色,但STL仍利用template實(shí)作了功能強(qiáng)大的iterator。

PHP5開(kāi)始支持了接口, 并且內(nèi)置了Iterator接口, 所以如果你定義了一個(gè)類,并實(shí)現(xiàn)了Iterator接口,那么你的這個(gè)類對(duì)象就是ZEND_ITER_OBJECT,否則就是ZEND_ITER_PLAIN_OBJECT.

對(duì)于ZEND_ITER_PLAIN_OBJECT的類,foreach會(huì)通過(guò)HASH_OF獲取該對(duì)象的默認(rèn)屬性數(shù)組,然后對(duì)該數(shù)組進(jìn)行foreach.

先來(lái)看下迭代器的定義,那就是提供一種方法順序訪問(wèn)一個(gè)聚合對(duì)象中各個(gè)元素,而又不暴露該對(duì)象的內(nèi)部顯示。它可幫助構(gòu)造特定的對(duì)象,那些對(duì)象能夠提供單一標(biāo)準(zhǔn)接口循環(huán)或迭代任何類型的可計(jì)數(shù)數(shù)據(jù)。來(lái)看下迭代器模式的結(jié)構(gòu)圖:

再來(lái)看下迭代器需要用到的內(nèi)部方法:

  • Iterator::current — Return the current element 返回當(dāng)前元素
  • Iterator::key — Return the key of the current element 返回當(dāng)前元素的鍵
  • Iterator::next — Move forward to next element 移向下一個(gè)元素
  • Iterator::rewind — Rewind the Iterator to the first element 重新回到第一個(gè)元素
  • Iterator::valid — Checks if current position is valid 檢查當(dāng)前位置的有效性

而對(duì)于ZEND_ITER_OBJECT的類對(duì)象,則會(huì)通過(guò)調(diào)用對(duì)象實(shí)現(xiàn)的Iterator接口相關(guān)函數(shù)來(lái)進(jìn)行foreach。

?php
/**
* Iterator模式的簡(jiǎn)單實(shí)現(xiàn)類
*/
class sample implements Iterator {
  private $_items ;
  public function __construct($data) {
    $this->_items = $data;
  }
  public function current() {
    return current($this->_items);
  }
  public function next() {
    next($this->_items);  
  }
  public function key() {
    return key($this->_items);
  }
  public function rewind() {
    reset($this->_items);
  }
  public function valid() {                                       
    return ($this->current() !== FALSE);
  }
}
/** DEMO */
$data = array(1, 2, 3, 4, 5);
$sa = new sample($data);
foreach ($sa AS $key => $row) {
  echo $key, ' ', $row, 'br />';
}
?>

舉幾個(gè)迭代器的使用范圍:

使用返回迭代器的包或庫(kù)時(shí)(如PHP5中的SPL迭代器)
無(wú)法在一次的調(diào)用獲取容器的所有元素時(shí)
要處理數(shù)量巨大的無(wú)素時(shí)(數(shù)據(jù)庫(kù)中的表以GB計(jì)的數(shù)據(jù))
……

不同的迭代器有不同的接口,例如PHP SPL迭代器中包括Next()(移動(dòng)到下一個(gè)元素),corrent()(返回當(dāng)前元素),valid()(檢查迭代結(jié)尾),rewind()(從頭重新開(kāi)始),key()(返回當(dāng)前元素的索引)。當(dāng)然你可以自己寫(xiě)適合自己用的迭代器,也可以用系統(tǒng)中的迭代器。

一般是使用foreach來(lái)使用迭代器,下面整理了一下代碼:

?php  
class sample implements Iterator
{
  private $_items = array(1,2,3,4,5,6,7);
  public function __construct() {
         ;//void
  }
  public function rewind() { reset($this->_items); }
  public function current() { return current($this->_items); }
  public function key() { return key($this->_items); }
  public function next() { return next($this->_items); }
  public function valid() { return ( $this->current() !== false ); }
}
$sa = new sample();
foreach($sa as $key => $val){
  print $key . "=>" .$val;
}
?> 

while循環(huán)也可以:

?php
while ($itertor->valid()){ //判斷是不是最后元素
 $element=$itertor->current(); //獲取當(dāng)前元素
 $itertor->next(); //移動(dòng)到下一個(gè)元素
}
?>

為什么要學(xué)習(xí)PHP的迭代器呢?有個(gè)很重要的原因:利用PHP的迭代器可以利用面向?qū)ο髮?shí)現(xiàn)常見(jiàn)的數(shù)據(jù)結(jié)構(gòu),例如列表,堆棧,隊(duì)列與圖。后面會(huì)做一個(gè)專題,用PHP實(shí)現(xiàn)大部分的數(shù)據(jù)結(jié)構(gòu),而且以面向?qū)ο蟮男问?。所以這里先預(yù)熱了一下PHP的迭代器。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接

您可能感興趣的文章:
  • PHP設(shè)計(jì)模式(九)外觀模式Facade實(shí)例詳解【結(jié)構(gòu)型】
  • PHP設(shè)計(jì)模式之外觀模式(Facade)入門與應(yīng)用詳解
  • thinkphp5.1框架中容器(Container)和門面(Facade)的實(shí)現(xiàn)方法分析
  • 詳解PHP中的外觀模式facade pattern
  • 學(xué)習(xí)php設(shè)計(jì)模式 php實(shí)現(xiàn)門面模式(Facade)
  • php設(shè)計(jì)模式 Facade(外觀模式)
  • PHP設(shè)計(jì)模式之工廠模式(Factory Pattern)的講解
  • 淺談PHP設(shè)計(jì)模式之門面模式Facade

標(biāo)簽:昭通 涼山 甘肅 韶關(guān) 梅河口 遼陽(yáng) 九江 十堰

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP設(shè)計(jì)模式之PHP迭代器模式講解》,本文關(guān)鍵詞  PHP,設(shè)計(jì)模式,之,迭代,器,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP設(shè)計(jì)模式之PHP迭代器模式講解》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于PHP設(shè)計(jì)模式之PHP迭代器模式講解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章