亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > PHP > 正文

PHP標準庫(PHP SPL)詳解

2024-05-05 00:07:30
字體:
來源:轉載
供稿:網友

什么是SPL?

SPL,PHP 標準庫(Standard PHP Library) ,此從 PHP 5.0 起內置的組件和接口,并且從 PHP5.3 已逐漸的成熟。SPL 其實在所有的 PHP5 開發環境中被內置,同時無需任何設置。

似乎眾多的 PHP 開發人員基本沒有使用它,甚至聞所未聞。究其原因,可以追述到它那陽春白雪般的說明文檔,使你忽略了「它的存在」。SPL 這塊寶石猶如鐵達尼的「海洋之心」般,被沉入海底。而現在它應該被我們撈起,并將它穿戴在應有的位置 ,而這也是這篇文章所要表述的觀點。

那么,SPL 提供了什么?

SPL 對 PHP 引擎進行了擴展,例如 ArrayAccess、Countable 和 SeekableIterator 等接口,它們用于以數組形式操作對象。同時,你還可以使用 RecursiveIterator、ArrayObejcts 等其他迭代器進行數據的迭代操作。

它還內置幾個的對象例如 Exceptions、SplObserver、Spltorage 以及 splautoloadregister、splclasses、iteratorapply 等的幫助函數(helper functions),用于重載對應的功能。

這些工具聚合在一起就好比是把多功能的瑞士軍刀,善用它們可以從質上提升 PHP 的代碼效率。那么,我們如何發揮它的威力?

如何使用SPL?

SPL提供了一組標準數據結構:

雙向鏈表

SplDoublyLinkedList

  • SplStack
  • SplQueue

雙鏈表是一種重要的線性存儲結構,對于雙鏈表中的每個節點,不僅僅存儲自己的信息,還要保存前驅和后繼節點的地址。

PHP SPL中的SplDoublyLinkedList類提供了對雙鏈表的操作。

SplDoublyLinkedList類摘要如下:

 SplDoublyLinkedList implements Iterator , ArrayAccess , Countable {   public __construct ( void )  public void add ( mixed $index , mixed $newval )  //雙鏈表的頭部節點  public mixed top ( void )  //雙鏈表的尾部節點  public mixed bottom ( void )  //雙聯表元素的個數  public int count ( void )  //檢測雙鏈表是否為空  public bool isEmpty ( void )  //當前節點索引  public mixed key ( void )  //移到上條記錄  public void prev ( void )  //移到下條記錄  public void next ( void )  //當前記錄  public mixed current ( void )  //將指針指向迭代開始處  public void rewind ( void )  //檢查雙鏈表是否還有節點  public bool valid ( void )    //指定index處節點是否存在  public bool offsetExists ( mixed $index )  //獲取指定index處節點值  public mixed offsetGet ( mixed $index )  //設置指定index處值  public void offsetSet ( mixed $index , mixed $newval )  //刪除指定index處節點  public void offsetUnset ( mixed $index )   //從雙鏈表的尾部彈出元素  public mixed pop ( void )  //添加元素到雙鏈表的尾部  public void push ( mixed $value )    //序列化存儲  public string serialize ( void )  //反序列化  public void unserialize ( string $serialized )  //設置迭代模式  public void setIteratorMode ( int $mode )  //獲取迭代模式SplDoublyLinkedList::IT_MODE_LIFO (Stack style) SplDoublyLinkedList::IT_MODE_FIFO (Queue style)  public int getIteratorMode ( void )  //雙鏈表的頭部移除元素  public mixed shift ( void )  //雙鏈表的頭部添加元素  public void unshift ( mixed $value ) }

使用起來也比較簡單

$list = new SplDoublyLinkedList(); $list->push('a'); $list->push('b'); $list->push('c'); $list->push('d');  $list->unshift('top'); $list->shift();  $list->rewind();//rewind操作用于把節點指針指向Bottom所在的節點 echo 'curren node:'.$list->current()."<br />";//獲取當前節點 $list->next();//指針指向下一個節點 echo 'next node:'.$list->current()."<br />"; $list->next(); $list->next(); $list->prev();//指針指向上一個節點 echo 'next node:'.$list->current()."<br />"; if($list->current())   echo 'current node is valid<br />'; else   echo 'current node is invalid<br />'; if($list->valid())//如果當前節點是有效節點,valid返回true   echo "valid list<br />"; else   echo "invalid list <br />"; var_dump(array(   'pop' => $list->pop(),   'count' => $list->count(),   'isEmpty' => $list->isEmpty(),   'bottom' => $list->bottom(),   'top' => $list->top() )); $list->setIteratorMode(SplDoublyLinkedList::IT_MODE_FIFO); var_dump($list->getIteratorMode()); for($list->rewind(); $list->valid(); $list->next()) {   echo $list->current().PHP_EOL; } var_dump($a = $list->serialize()); //print_r($list->unserialize($a)); $list->offsetSet(0,'new one'); $list->offsetUnset(0); var_dump(array(   'offsetExists' => $list->offsetExists(4),   'offsetGet' => $list->offsetGet(0), )); var_dump($list); //堆棧,先進后出 $stack = new SplStack();//繼承自SplDoublyLinkedList類 $stack->push("a<br />"); $stack->push("b<br />"); echo $stack->pop(); echo $stack->pop(); echo $stack->offsetSet(0,'B');//堆棧的offset=0是Top所在的位置,offset=1是Top位置節點靠近bottom位置的相鄰節點,以此類推 $stack->rewind();//雙向鏈表的rewind和堆棧的rewind相反,堆棧的rewind使得當前指針指向Top所在的位置,而雙向鏈表調用之后指向bottom所在位置 echo 'current:'.$stack->current().'<br />'; $stack->next();//堆棧的next操作使指針指向靠近bottom位置的下一個節點,而雙向鏈表是靠近top的下一個節點 echo 'current:'.$stack->current().'<br />'; echo '<br /><br />'; //隊列,先進先出 $queue = new SplQueue();//繼承自SplDoublyLinkedList類 $queue->enqueue("a<br />");//插入一個節點到隊列里面的Top位置 $queue->enqueue("b<br />"); $queue->offsetSet(0,'A');//堆棧的offset=0是Top所在的位置,offset=1是Top位置節點靠近bottom位置的相鄰節點,以此類推 echo $queue->dequeue(); echo $queue->dequeue(); echo "<br /><br />";

重載 autoloader

如果你是位「教科書式的程序員」,那么你保證了解如何使用 __autoload 去代替 includes/requires 操作惰性載入對應的類,對不?

但久之,你會發現你已經陷入了困境,首先是你要保證你的類文件必須在指定的文件路徑中,例如在 Zend 框架中你必須使用「_」來分割類、方法名稱(你如何解決這一問題?)。

另外的一個問題,就是當項目變得越來越復雜, __autoload 內的邏輯也會變得相應的復雜。到最后,甚至你會加入異常判斷,以及將所有的載入類的邏輯如數寫到其中。

大家都知道「雞蛋不能放到一個籃子中」,利用 SPL 可以分離 __autoload 的載入邏輯。只需要寫個你自己的 autoload 函數,然后利用 SPL 提供的函數重載它。

例如上述 Zend 框架的問題,你可以重載 Zend loader 對應的方法,如果它沒有找到對應的類,那么就使用你先前定義的函數。

<?phpclass MyLoader {  public static function doAutoload($class) {    // 本模塊對應的 autoload 操作  }}spl_autoload_register( array('MyLoader', 'doAutoload') );?>

正如你所見, spl autoload register 還能以數組的形式加入多個載入邏輯。同時,你還可以利用spl autoload unregister 移除已經不再需要的載入邏輯,這功能總會用到的。

迭代器

迭代是常見設計模式之一,普遍應用于一組數據中的統一的遍歷操作??梢院敛豢鋸埖恼f,SPL 提供了所有你需要的對應數據類型的迭代器。

有個非常好的案例就是遍歷目錄。常規的做法就是使用 scandir ,然后跳過「.「 和 「..」,以及其它未滿足條件的文件。例如你需要遍歷個某個目錄抽取其中的圖片文件,就需要判斷是否是 jpg、gif 結尾。

下面的代碼就是使用 SPL 的迭代器執行上述遞歸尋找指定目錄中的圖片文件的例子:

<?phpclass RecursiveFileFilterIterator extends FilterIterator {  // 滿足條件的擴展名  protected $ext = array('jpg','gif');  /**   * 提供 $path 并生成對應的目錄迭代器   */  public function __construct($path) {    parent::__construct(new RecursiveIteratorIterator(new RecursiveDirectoryIterator($path)));  }  /**   * 檢查文件擴展名是否滿足條件   */  public function accept() {    $item = $this->getInnerIterator();    if ($item->isFile() &&         in_array(pathinfo($item->getFilename(), PATHINFO_EXTENSION), $this->ext)) {      return TRUE;    }  }}// 實例化foreach (new RecursiveFileFilterIterator('/path/to/something') as $item) {  echo $item . PHP_EOL;}?>

你可能會說,這不是花了更多的代碼去辦同一件事情嗎?那么,查看上面的代碼,你不是擁有了具有高度重用而且可以測試的代碼了嗎 :)

下面是 SPL 提供的其他的迭代器:

  • RecursiveIterator
  • RecursiveIteratorIterator
  • OuterIterator
  • IteratorIterator
  • FilterIterator
  • RecursiveFilterIterator
  • ParentIterator
  • SeekableIterator
  • LimitIterator
  • GlobIterator
  • CachingIterator
  • RecursiveCachingIterator
  • NoRewindIterator
  • AppendIterator
  • RecursiveIteratorIterator
  • InfiniteIterator
  • RegexIterator
  • RecursiveRegexIterator
  • EmptyIterator
  • RecursiveTreeIterator
  • ArrayIterator

自 PHP5.3 開始,會內置其他更多的迭代器,我想你都可以嘗試下,或許它能改變你編寫傳統代碼的習慣。

SplFixedArray

SPL 還內置了一系列的數組操作工具,例如可以使用 SplFixedArray 實例化一個固定長度的數組。那么為什么要使用它?因為它更快,甚至它關系著你的工資問題 :)

我們知道 PHP 常規的數組包含不同類型的鍵,例如數字、字符串等,并且長度是可變的。正是因為這些「高級功能」,PHP 以散列(hash)的方式通過鍵得到對應的值 -- 其實這在特定情況這會造成性能問題。

而 SplFixedArray 因為是使用固定的數字鍵,所以它并沒有使用散列存儲方式。不確切的說,甚至你可以認為它就是個 C 數組。這就是為什么 SplFixedArray 會比通常數組要快的原因(僅在 PHP5.3 中)。

那到底有多快呢,下面的組數據可以讓你窺其究竟。

PHP,標準庫,SPL

如果你需要大量的數組操作,那么你可以嘗試下,相信它是值得信賴的。

數據結構

同時 SPL 還提供了些數據結構基本類型的實現 。雖然我們可以使用傳統的變量類型來描述數據結構,例如用數組來描述堆棧(Strack)-- 然后使用對應的方式 pop 和 push(arraypop()、arraypush()),但你得時刻小心,·因為畢竟它們不是專門用于描述數據結構的 -- 一次誤操作就有可能破壞該堆棧。

而 SPL 的 SplStack 對象則嚴格以堆棧的形式描述數據,并提供對應的方法。同時,這樣的代碼應該也能理解它在操作堆棧而非某個數組,從而能讓你的同伴更好的理解相應的代碼,并且它更快。

最后,可能上述那些慘白的例子還不足矣「誘惑你」去使用 SPL。實踐出真知,SPL 更多、更強大的功能需要你自己去挖掘。而它正如寶石般的慢慢雕砌,才能散發光輝。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
午夜精品视频在线| 国产日韩av高清| 91tv亚洲精品香蕉国产一区7ujn| 欧洲成人免费aa| 亚洲一区中文字幕| 亚洲视频在线看| 日韩av在线免费看| 色综合天天综合网国产成人网| 色偷偷偷亚洲综合网另类| 国产精品人人做人人爽| 国产成人精品免高潮费视频| 欧美亚洲视频一区二区| 成人日韩在线电影| 成人国产亚洲精品a区天堂华泰| 亚洲欧洲日本专区| 日韩大片在线观看视频| 91精品视频专区| 日韩一二三在线视频播| 在线视频欧美性高潮| 欧美电影免费观看大全| 欧美午夜宅男影院在线观看| 成人做爽爽免费视频| 日韩女优人人人人射在线视频| 国产丝袜精品第一页| 久久久久国产一区二区三区| 成人国产在线激情| 欧美日韩国内自拍| 日韩网站在线观看| 少妇高潮久久77777| 精品久久久国产| 亚洲美女又黄又爽在线观看| 精品毛片网大全| 亚洲精品中文字幕有码专区| 一区二区三区美女xx视频| 欧美一区二粉嫩精品国产一线天| 精品视频在线观看日韩| 成人午夜激情免费视频| 欧美国产日韩二区| 亚洲国产精品电影| 色综合亚洲精品激情狠狠| 国产z一区二区三区| 亚洲女人天堂av| 国产69精品久久久久99| 95av在线视频| 国产成人免费av| 欧美日韩福利在线观看| 日韩中文字幕在线精品| 亚洲精品视频二区| 日韩综合视频在线观看| 久久久久久久一区二区| 日韩一区二区三区国产| 欧美亚洲日本黄色| 在线丨暗呦小u女国产精品| 热久久美女精品天天吊色| 91网站在线看| 亚洲免费电影在线观看| 成人疯狂猛交xxx| 日本精品免费观看| 成人精品在线视频| 亚洲精品在线观看www| 中文字幕最新精品| 欧洲精品毛片网站| 亚洲美女自拍视频| 欧美国产乱视频| 国产精品美女www爽爽爽视频| 欧美国产视频一区二区| 欧美电影在线播放| 色偷偷av一区二区三区| 中文字幕在线成人| 热久久免费视频精品| 日韩精品免费一线在线观看| 国产日韩在线看| 中文字幕视频在线免费欧美日韩综合在线看| 国产成人精品亚洲精品| 亚洲直播在线一区| 久久99国产综合精品女同| 亚洲成色777777女色窝| 亚洲国产成人爱av在线播放| 欧美日本国产在线| 国产精品日韩在线一区| 亚洲福利在线视频| 日本一区二区不卡| 亚洲欧美日韩区| 久久中文字幕在线| 日韩中文娱乐网| 日韩电视剧在线观看免费网站| 精品成人乱色一区二区| 精品爽片免费看久久| 中文字幕国产精品久久| 欧美多人乱p欧美4p久久| 欧美色另类天堂2015| 亚洲影院色无极综合| 亚洲国产天堂久久国产91| 国产成人精品久久| 欧美在线视频免费| 欧美激情2020午夜免费观看| 亚洲激情国产精品| 中文字幕最新精品| 美女视频久久黄| 亚洲人成在线播放| 精品视频偷偷看在线观看| 日韩精品一二三四区| 国产亚洲在线播放| 色综合导航网站| 国产精品丝袜高跟| 亚洲的天堂在线中文字幕| 日韩一级黄色av| 91在线|亚洲| 欧美日韩在线观看视频| 一本大道香蕉久在线播放29| 国产精品91免费在线| 5278欧美一区二区三区| 欧美一区二粉嫩精品国产一线天| 色妞欧美日韩在线| 黑人巨大精品欧美一区免费视频| 亚洲一区精品电影| 在线观看日韩专区| 亚洲成**性毛茸茸| 中文综合在线观看| 亚洲午夜精品久久久久久久久久久久| 国产精品综合不卡av| 中文字幕在线观看日韩| 一区二区三区日韩在线| 91夜夜揉人人捏人人添红杏| 亚洲一区二区三区成人在线视频精品| 久久久91精品国产一区不卡| 久久久久久久久中文字幕| 国产精品www网站| 九色91av视频| 久久精品视频在线| 一区二区三区高清国产| 日本精品久久电影| 一级做a爰片久久毛片美女图片| 亚洲欧美www| 成年人精品视频| 欧美美女18p| 国产在线精品成人一区二区三区| 日韩在线播放av| 一本一本久久a久久精品综合小说| 综合网日日天干夜夜久久| 亚洲一区二区三区香蕉| 久久久久久九九九| 两个人的视频www国产精品| 久久久久久久亚洲精品| 成人情趣片在线观看免费| 国产精品99导航| 国产精品av在线播放| www亚洲精品| 中文字幕在线成人| 最新91在线视频| 久久青草精品视频免费观看| 91在线视频导航| 91精品在线观| 亚洲国产成人精品电影| 国产精品成人免费视频| 中文在线资源观看视频网站免费不卡| 一区二区亚洲精品国产| 伊人伊成久久人综合网小说| 欧美日韩国产一区二区三区| 亚洲图片制服诱惑| 亚洲天堂av网| 一区二区三区日韩在线| 色偷偷9999www| 大量国产精品视频|