欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP設計模式入門之迭代器模式原理與實現(xiàn)方法分析

 更新時間:2020年04月26日 11:29:22   作者:dongxie548  
這篇文章主要介紹了PHP設計模式入門之迭代器模式原理與實現(xiàn)方法,結合實例形式分析了PHP迭代器模式基本概念、原理、實現(xiàn)方法及操作注意事項,需要的朋友可以參考下

本文實例講述了PHP設計模式入門之迭代器模式。分享給大家供大家參考,具體如下:

在深入研究這個設計模式之前,我們先來看一道面試題,來自鳥哥的博客,

題目是這樣的:

使對象可以像數(shù)組一樣進行foreach循環(huán),要求屬性必須是私有。

不使用迭代器模式很難實現(xiàn),先看實現(xiàn)的代碼:

sample.php

<?php
class Sample implements Iterator{
 private $_arr;
 
 public function __construct(Array $arr){
 $this->_arr = $arr;
 }
 
 public function current(){
   return current($this->_arr);
 }
 
 public function next(){
   return next($this->_arr);
 }
 
 public function key(){
   return key($this->_arr);
 }
 
 public function valid(){
   return $this->current() !== false;
 }
 
 public function rewind(){
  reset($this->_arr);
 }
}

index.php

<?php
require 'Sample.php';
 
$arr = new Sample(['max', 'ben', 'will']); 
 
foreach ($arr as $k=>$v){
  echo $k."-".$v."<br />";
}

其中Iterator接口來自php的spl類庫,在寫完設計模式的相關文章之后,將會進一步研究這個類庫。

另外在網(wǎng)上找到了一段yii框架中關于迭代器模式的實現(xiàn)代碼:

class CMapIterator implements Iterator {
/**
* @var array the data to be iterated through
*/
  private $_d;
/**
* @var array list of keys in the map
*/
  private $_keys;
/**
* @var mixed current key
*/
  private $_key;
 
/**
* Constructor.
* @param array the data to be iterated through
*/
  public function __construct(&$data) {
    $this->_d=&$data;
    $this->_keys=array_keys($data);
  }
 
/**
* Rewinds internal array pointer.
* This method is required by the interface Iterator.
*/
  public function rewind() {                                         
    $this->_key=reset($this->_keys);
  }
 
/**
* Returns the key of the current array element.
* This method is required by the interface Iterator.
* @return mixed the key of the current array element
*/
  public function key() {
    return $this->_key;
  }
 
/**
* Returns the current array element.
* This method is required by the interface Iterator.
* @return mixed the current array element
*/
  public function current() {
    return $this->_d[$this->_key];
  }
 
/**
* Moves the internal pointer to the next array element.
* This method is required by the interface Iterator.
*/
  public function next() {
    $this->_key=next($this->_keys);
  }
 
/**
* Returns whether there is an element at current position.
* This method is required by the interface Iterator.
* @return boolean
*/
  public function valid() {
    return $this->_key!==false;
  }
}
 
$data = array('s1' => 11, 's2' => 22, 's3' => 33);
$it = new CMapIterator($data);
foreach ($it as $row) {
  echo $row, '<br />';
}

關于迭代器設計模式官方的定義是:使用迭代器模式來提供對聚合對象的統(tǒng)一存取,即提供一個外部的迭代器來對聚合對象進行訪問和遍歷 , 而又不需暴露該對象的內(nèi)部結構。又叫做游標(Cursor)模式。

好吧,我不是很能理解。為什么明明數(shù)組已經(jīng)可以用foreach來遍歷了還要用這樣一種迭代器模式來實現(xiàn),只有等待工作經(jīng)驗的加深來進一步理解吧。

參考文檔:

http://www.dbjr.com.cn/article/184182.htm

http://www.dbjr.com.cn/article/185478.htm

http://www.dbjr.com.cn/article/185483.htm

更多關于PHP相關內(nèi)容感興趣的讀者可查看本站專題:《php面向?qū)ο蟪绦蛟O計入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《PHP基本語法入門教程》、《PHP運算與運算符用法總結》、《php字符串(string)用法總結》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總

希望本文所述對大家PHP程序設計有所幫助。

相關文章

最新評論