主頁 > 知識(shí)庫 > PHP SPL 被遺落的寶石【SPL應(yīng)用淺析】

PHP SPL 被遺落的寶石【SPL應(yīng)用淺析】

熱門標(biāo)簽:長沙做地圖標(biāo)注公司 地圖標(biāo)注專員怎么樣 福建銀行智能外呼系統(tǒng)價(jià)格 遼寧ai電銷機(jī)器人價(jià)格 四川保險(xiǎn)智能外呼系統(tǒng)供應(yīng)商 電話機(jī)器人銷售主要負(fù)責(zé)什么 寧波外呼營銷系統(tǒng) 上海做外呼線路的通信公司 房產(chǎn)中介用的是什么外呼系統(tǒng)

本文實(shí)例講述了PHP SPL應(yīng)用方法。分享給大家供大家參考,具體如下:

Rafael Dohms 上面的篇文章 讓我為之驚艷,忍不住就翻譯了下來,同時(shí)補(bǔ)充了部分內(nèi)容。

SPL,PHP 標(biāo)準(zhǔn)庫(Standard PHP Library) ,從 PHP 5.0 起內(nèi)置的組件和接口,并且從 PHP5.3 已逐漸的成熟。SPL 其實(shí)在所有的 PHP5 開發(fā)環(huán)境中被內(nèi)置,同時(shí)無需任何設(shè)置。

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

那么,SPL 提供了什么?

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

它還內(nèi)置幾個(gè)的對(duì)象例如 Exceptions、SplObserverSpltorage 以及 splautoloadregister、splclasses、iteratorapply 等的幫助函數(shù)(helper functions),用于重載對(duì)應(yīng)的功能。

這些工具聚合在一起就好比是把多功能的瑞士軍刀,善用它們可以從質(zhì)上提升 PHP 的代碼效率。那么,我們?nèi)绾伟l(fā)揮它的威力?

重載 autoloader

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

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

另外的一個(gè)問題,就是當(dāng)項(xiàng)目變得越來越復(fù)雜, __autoload 內(nèi)的邏輯也會(huì)變得相應(yīng)的復(fù)雜。到最后,甚至你會(huì)加入異常判斷,以及將所有的載入類的邏輯如數(shù)寫到其中。

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

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

?php
class MyLoader {
  public static function doAutoload($class) {
    // 本模塊對(duì)應(yīng)的 autoload 操作
  }
}
spl_autoload_register( array('MyLoader', 'doAutoload') );
?>

正如你所見, spl_autoload_register 還能以數(shù)組的形式加入多個(gè)載入邏輯。同時(shí),你還可以利用spl_autoload_unregister 移除已經(jīng)不再需要的載入邏輯,這功能總會(huì)用到的。

迭代器

迭代是常見設(shè)計(jì)模式之一,普遍應(yīng)用于一組數(shù)據(jù)中的統(tǒng)一的遍歷操作。可以毫不夸張的說,SPL 提供了所有你需要的對(duì)應(yīng)數(shù)據(jù)類型的迭代器。

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

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

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

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

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

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

自 PHP5.3 開始,會(huì)內(nèi)置其他更多的迭代器,我想你都可以嘗試下,或許它能改變你編寫傳統(tǒng)代碼的習(xí)慣。

SplFixedArray

SPL 還內(nèi)置了一系列的數(shù)組操作工具,例如可以使用 SplFixedArray 實(shí)例化一個(gè)固定長度的數(shù)組。那么為什么要使用它?因?yàn)樗欤踔了P(guān)系著你的工資問題 :)

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

而 SplFixedArray 因?yàn)槭鞘褂霉潭ǖ臄?shù)字鍵,所以它并沒有使用散列存儲(chǔ)方式。不確切的說,甚至你可以認(rèn)為它就是個(gè) C 數(shù)組。這就是為什么 SplFixedArray 會(huì)比通常數(shù)組要快的原因(僅在 PHP5.3 中)。

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

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

數(shù)據(jù)結(jié)構(gòu)

同時(shí) SPL 還提供了些數(shù)據(jù)結(jié)構(gòu)基本類型的實(shí)現(xiàn) 。雖然我們可以使用傳統(tǒng)的變量類型來描述數(shù)據(jù)結(jié)構(gòu),例如用數(shù)組來描述堆棧(Strack)-- 然后使用對(duì)應(yīng)的方式 pop 和 push(arraypop()arraypush()),但你得時(shí)刻小心,·因?yàn)楫吘顾鼈儾皇菍iT用于描述數(shù)據(jù)結(jié)構(gòu)的 -- 一次誤操作就有可能破壞該堆棧。

而 SPL 的 SplStack 對(duì)象則嚴(yán)格以堆棧的形式描述數(shù)據(jù),并提供對(duì)應(yīng)的方法。同時(shí),這樣的代碼應(yīng)該也能理解它在操作堆棧而非某個(gè)數(shù)組,從而能讓你的同伴更好的理解相應(yīng)的代碼,并且它更快。

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

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

希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • PHP設(shè)計(jì)模式之迭代器模式
  • PHP設(shè)計(jì)模式之迭代器模式的深入解析
  • PHP迭代器的內(nèi)部執(zhí)行過程詳解
  • PHP迭代器實(shí)現(xiàn)斐波納契數(shù)列的函數(shù)
  • PHP迭代器接口Iterator用法分析
  • PHP聚合式迭代器接口IteratorAggregate用法分析
  • PHP迭代器和迭代的實(shí)現(xiàn)與使用方法分析
  • PHP SPL標(biāo)準(zhǔn)庫之?dāng)?shù)據(jù)結(jié)構(gòu)棧(SplStack)介紹
  • PHP SPL標(biāo)準(zhǔn)庫中的常用函數(shù)介紹
  • PHP基于SPL實(shí)現(xiàn)的迭代器模式示例

標(biāo)簽:宜春 深圳 佛山 澳門 延安 工商登記 常德 宿遷

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