《PHP實(shí)戰(zhàn):Zend Framework教程之Autoloading用法詳解》要點(diǎn):
本文介紹了PHP實(shí)戰(zhàn):Zend Framework教程之Autoloading用法詳解,希望對(duì)您有用。如果有疑問(wèn),可以聯(lián)系我們。
PHP應(yīng)用本文實(shí)例講述了Zend Framework教程之Autoloading用法.分享給大家供大家參考,具體如下:
PHP應(yīng)用一、概述
PHP應(yīng)用自動(dòng)加載是一種機(jī)制,無(wú)需依賴(lài)手動(dòng)編寫(xiě)PHP代碼.參考?PHP手冊(cè)自動(dòng)加載,一旦自動(dòng)加載器被定義,你試圖使用一個(gè)沒(méi)有定義的類(lèi)或接口的情況下,它會(huì)自動(dòng)被調(diào)用.
PHP應(yīng)用使用自動(dòng)加載,在項(xiàng)目中你不必?fù)?dān)心類(lèi)的存放位置.定義一個(gè)良好定義的自動(dòng)加載器,您不需要考慮一個(gè)類(lèi)文件相對(duì)于當(dāng)前類(lèi)文件的位置,您只需使用類(lèi),自動(dòng)加載器將自動(dòng)查找文件.
PHP應(yīng)用此外,自動(dòng)加載,確保只加載一次,提升了性能 -所以可以用它替代require_once().
PHP應(yīng)用Zend Framework 鼓勵(lì)使用自動(dòng)加載,并提供了許多工具實(shí)現(xiàn)自動(dòng)加載代碼庫(kù)以及應(yīng)用程序代碼.下面將介紹這些工具,以及如何有效地使用它們.
PHP應(yīng)用自動(dòng)加載的實(shí)現(xiàn)約定
PHP應(yīng)用類(lèi)命名約定
PHP應(yīng)用Zend Framework借鑒了 PEAR的想法,即類(lèi)名與文件系統(tǒng)的1:1的關(guān)系.簡(jiǎn)單地說(shuō),下劃線(xiàn)字符("_")替換目錄分隔,以代表該文件的路徑,然后添加后綴“.php”.例如,類(lèi)“Foo_Bar_Baz”將對(duì)應(yīng)文件系統(tǒng)上的"Foo/Bar/Baz.php".假設(shè)已通過(guò)PHP的include_path設(shè)置類(lèi)的位置,這使得可以通過(guò) include() 和 require()找到相對(duì)include_path中設(shè)置的路徑查找文件名.
PHP應(yīng)用此外,推薦使用供應(yīng)商名稱(chēng)或項(xiàng)目名稱(chēng)作為前綴.這意味著,你寫(xiě)的所有的類(lèi)都有一個(gè)共同的類(lèi)前綴,例如,Zend Framework的所有代碼前綴為“Zend_”.這種命名約定有助于防止命名沖突.在ZendFramework中,我們經(jīng)常提到“namespace”前綴,要注意不要把它與PHP的本地命名空間混淆.
PHP應(yīng)用自動(dòng)加載器設(shè)計(jì)約定
PHP應(yīng)用Zend Framework通過(guò)Zend_Loader_Autoloader實(shí)現(xiàn)支持自動(dòng)加載的,主要提供有以下目標(biāo)和設(shè)計(jì)元素:
PHP應(yīng)用提供命名空間匹配.如果類(lèi)的命名空間前綴是沒(méi)有注冊(cè)的命名空間,會(huì)返回FALSE.
PHP應(yīng)用允許定義自動(dòng)加載器作為一個(gè)備用的自動(dòng)加載器.一個(gè)團(tuán)隊(duì)可能分布廣泛,或使用一個(gè)為定義的命名空間前綴情況下,它會(huì)嘗試匹配任何命名空間前綴.但是,這種做法是不推薦,因?yàn)樗赡軙?huì)導(dǎo)致不必要的查找.
允許開(kāi)啟禁止錯(cuò)誤提示. 因此,默認(rèn)情況下,它應(yīng)該處于關(guān)閉狀態(tài).開(kāi)發(fā)階段,可以啟用它.
PHP應(yīng)用可以自定義自動(dòng)加載.一些開(kāi)發(fā)商不希望使用Zend_Loader::loadClass()自動(dòng)加載,但仍想使用Zend Framework的自動(dòng)加載機(jī)制. Zend_Loader_Autoloader允許使用自定義的自動(dòng)加載.
PHP應(yīng)用允許使用SPL自動(dòng)加載回調(diào)鏈.這樣做的目的是允許指定額外的自動(dòng)加載器 .
PHP應(yīng)用二、用法:
PHP應(yīng)用通常,只需將需要引入包含類(lèi),然后實(shí)例化它即可.由于Zend_Loader_Autoloader采用的單例模式,可以使用getInstance()辦法來(lái)獲取一個(gè)實(shí)例.
PHP應(yīng)用
require_once 'Zend/Loader/Autoloader.php';
Zend_Loader_Autoloader::getInstance();
PHP應(yīng)用默認(rèn)情況下,可以加載命名空間前綴為"Zend_"或 "ZendX_"的任何類(lèi),只要確保已經(jīng)指定include_path.
如果想使用其他的命名空間前綴?最好的,最簡(jiǎn)單的辦法是調(diào)用registerNamespace() 辦法.您可以通過(guò)傳遞一個(gè)單一的命名空間前綴,或一個(gè)數(shù)組:
PHP應(yīng)用
require_once 'Zend/Loader/Autoloader.php';
$loader = Zend_Loader_Autoloader::getInstance();
$loader->registerNamespace('Foo_');
$loader->registerNamespace(array('Foo_', 'Bar_'));
PHP應(yīng)用或者,你可以把Zend_Loader_Autoloader作為一個(gè)“備用”自動(dòng)加載器.這意味著如果命名空間無(wú)論是否定義,都會(huì)嘗試自動(dòng)加載.
PHP應(yīng)用
$loader->setFallbackAutoloader(true);
PHP應(yīng)用(注意:這種方式是不推薦的,盡量不要使用).
PHP應(yīng)用Zend_Loader_Autoloader的內(nèi)部實(shí)現(xiàn)是使用 Zend_Loader::loadClass() 加載類(lèi)的.該辦法的使用 include() 來(lái)嘗試加載給定的類(lèi)文件. include()將返回一個(gè)布爾值,如果沒(méi)有成功返回FALSE - ??而且還發(fā)出PHP警告. 可能會(huì)導(dǎo)致以下問(wèn)題:
PHP應(yīng)用如果啟用了display_errors,警告將包含在輸出中.
PHP應(yīng)用根據(jù)你所配置的error_reporting級(jí)別,它也可以輸出到日志中.
可以禁止這些錯(cuò)誤消息,具體如下:(但注意,display_errors啟用時(shí),錯(cuò)誤日志將始終顯示.)
PHP應(yīng)用
$autoloader->suppressNotFoundWarnings(true);
PHP應(yīng)用選擇一個(gè)Zend Framework的版本
PHP應(yīng)用ZendFramework/
|-- 1.9.2/
|?? |-- library/
|-- ZendFramework-1.9.1-minimal/
|?? |-- library/
|-- 1.8.4PL1/
|?? |-- library/
|-- 1.8.4/
|?? |-- library/
|-- ZendFramework-1.8.3/
|?? |-- library/
|-- 1.7.8/
|?? |-- library/
|-- 1.7.7/
|?? |-- library/
|-- 1.7.6/
|?? |-- library/
PHP應(yīng)用
$autoloader->setZfPath($path, 'latest');
PHP應(yīng)用
$autoloader->setZfPath($path, '1.8');
PHP應(yīng)用
$autoloader->setZfPath($path, '1.7.7');
PHP應(yīng)用也可以使用配置文件
PHP應(yīng)用
[production]
autoloaderZfPath = "path/to/ZendFramework"
autoloaderZfVersion = "1.7.7"
[qa]
autoloaderZfVersion = "1.8"
[development]
autoloaderZfVersion = "latest"
PHP應(yīng)用Autoloader接口
PHP應(yīng)用注:命名空間前綴和PHP命名空間
PHP應(yīng)用PHP5.3已經(jīng)發(fā)布.該版本中,PHP現(xiàn)在已經(jīng)正式支持命名空間.
PHP應(yīng)用然而,Zend Framework的命名空間和PHP 5.3的命名空間完全不同的. Zend Framework中,提到的“命名空間”,是指一個(gè)類(lèi)前綴.例如,所有的Zend Framework的類(lèi)名稱(chēng)的前綴“Zend_”. 這是我們指定的“命名空間”.
PHP應(yīng)用在Zend Framework 2.0.0使用了原生的PHP命名空間.
PHP應(yīng)用自動(dòng)加載器除了能夠指定任意回調(diào)以外,Zend Framework還定義了一個(gè)需要自動(dòng)加載類(lèi)實(shí)現(xiàn)的接口Zend_Loader_Autoloader_Interface:
PHP應(yīng)用
interface Zend_Loader_Autoloader_Interface
{
public function autoload($class);
}
PHP應(yīng)用如果您希望在Zend Framework中使用自定義的自動(dòng)加載器,可以使用 Zend_Loader_Autoloader的 pushAutoloader()和unshiftAutoloader()辦法.
通過(guò)這些辦法將在Zend Framework的內(nèi)部自動(dòng)裝載器之后追加或之前使用自定義的加載器.
PHP應(yīng)用每個(gè)辦法接受一個(gè)可選的第二個(gè)參數(shù),類(lèi)的命名空間前綴.自動(dòng)加載器只查找給定的類(lèi)前綴.如果不是指定的類(lèi)前綴,將跳過(guò)自動(dòng)加載器 , 這可能是一種性能改進(jìn)方式.
PHP應(yīng)用當(dāng)使用這個(gè)接口時(shí),你需要傳遞類(lèi)實(shí)例到Zend_Loader_Autoloader類(lèi)的pushAutoloader()和unshiftAutoloader()辦法,具體如下:
PHP應(yīng)用
// Append function 'my_autoloader' to the stack,
// to manage classes with the prefix 'My_':
$loader->pushAutoloader('my_autoloader', 'My_');
// Prepend static method Foo_Loader::autoload() to the stack,
// to manage classes with the prefix 'Foo_':
$loader->unshiftAutoloader(array('Foo_Loader', 'autoload'), 'Foo_');
// Assume Foo_Autoloader implements Zend_Loader_Autoloader_Interface:
$foo = new Foo_Autoloader();
$autoloader->pushAutoloader($foo, 'Foo_');
PHP應(yīng)用Zend_Loader_Autoloader的相關(guān)辦法
Method | Return Value | Parameters | Description |
---|---|---|---|
getInstance() | Zend_Loader_Autoloader | N/A |
PHP應(yīng)用獲取實(shí)例 |
resetInstance() | void |
N/A |
PHP應(yīng)用重置Zend_Loader_Autoloadersingleton實(shí)例的狀態(tài),恢復(fù)它的原始狀態(tài),注銷(xiāo)所有的自動(dòng)加載器回調(diào)和所有注冊(cè)的命名空間. |
autoload($class) | string|FALSE |
|
PHP應(yīng)用試圖加載一個(gè)類(lèi). |
setDefaultAutoloader($callback) | Zend_Loader_Autoloader |
|
PHP應(yīng)用指定默認(rèn)的加載器回調(diào) |
getDefaultAutoloader() | callback |
N/A |
PHP應(yīng)用獲取默認(rèn)的加載器接口;默認(rèn)是Zend_Loader::loadClass(). |
setAutoloaders(array $autoloaders) | Zend_Loader_Autoloader |
|
PHP應(yīng)用設(shè)置在自動(dòng)加載器棧使用具體的自動(dòng)加載器列表.自動(dòng)加載器列表中的每個(gè)項(xiàng)目必須是PHPcallback. |
getAutoloaders() | Array | N/A |
PHP應(yīng)用? |
getNamespaceAutoloaders($namespace) | Array |
|
PHP應(yīng)用獲取所有已注冊(cè)的自動(dòng)加載器來(lái)加載一個(gè)特定的的命名空間. |
registerNamespace($namespace) | Zend_Loader_Autoloader |
|
PHP應(yīng)用注冊(cè)命名空間. If$namespace?is a string, it registers that namespace; if it's an array of strings, registers each as a namespace. |
unregisterNamespace($namespace) | Zend_Loader_Autoloader |
|
|
getRegisteredNamespaces() | Array | N/A | |
suppressNotFoundWarnings($flag = null) | boolean|Zend_Loader_Autoloader |
|
PHP應(yīng)用錯(cuò)誤提示 |
setFallbackAutoloader($flag) | Zend_Loader_Autoloader |
|
PHP應(yīng)用? |
isFallbackAutoloader() | Boolean | N/A |
PHP應(yīng)用? |
getClassAutoloaders($class) | Array |
|
PHP應(yīng)用? |
unshiftAutoloader($callback, $namespace = '') | Zend_Loader_Autoloader |
|
PHP應(yīng)用? |
pushAutoloader($callback, $namespace = '') | Zend_Loader_Autoloader |
|
PHP應(yīng)用? |
removeAutoloader($callback, $namespace = '') | Zend_Loader_Autoloader |
|
PHP應(yīng)用更多關(guān)于zend相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《Zend FrameWork框架入門(mén)教程》、《php優(yōu)秀開(kāi)發(fā)框架總結(jié)》、《Yii框架入門(mén)及常用技巧總結(jié)》、《ThinkPHP入門(mén)教程》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門(mén)教程》、《php+mysql數(shù)據(jù)庫(kù)操作入門(mén)教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
PHP應(yīng)用希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所贊助.
歡迎參與《PHP實(shí)戰(zhàn):Zend Framework教程之Autoloading用法詳解》討論,分享您的想法,維易PHP學(xué)院為您提供專(zhuān)業(yè)教程。
轉(zhuǎn)載請(qǐng)注明本頁(yè)網(wǎng)址:
http://www.fzlkiss.com/jiaocheng/7394.html