程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> PHP 5.3中的命名空間使用方法淺述

PHP 5.3中的命名空間使用方法淺述

編輯:關於PHP編程

PHP 5.3 的一個新的重要特性就是 命名空間(namespace)。

這一特性在 PHP5.0x 時候就提出過,後來被取消並安排在 PHP6 中實現。而此次又再次“提前”到了 PHP 5.3 發布,可見開發人員對其的重視以及謹慎的態度。

官方發布時說明文檔的內容可能已過期(documentation maybe out dated),所以在這裡簡單的說明命名空間的用法:首先是聲明一個命名空間,加入了新的關鍵字 namespace ,其應在類文件的開頭

  1. <?php  
  2. namespace Project::Module;   
  3.  
  4. class User {  
  5. const STATUS_OK = true;  
  6.  
  7. function register($data) {  
  8. ...  
  9. }  
  10.  
  11. ...  
  12. }  

然後在控制器中(可能是其他文件)就可以這樣調用

  1. $user = new Project::Module::User();   
  2. $user->register($register_info); 

的確與平常的並無兩樣,但是我們可以將兩個相互獨立的類聯系起來。比如

  1. Project::Module::User;   
  2. Project::Module::Blog;  

這樣就能從語言本身更容易描述和理解變量、類之間的關系,從而避免了“傳統”上的 Project_Module_Blog 這樣冗長的命名方式。

上面的說明可能很難說明使用命名空間帶來了什麼好處,新增加的 use 和 as 關鍵字或許能更好的說明問題。use 和 as 語句可以引用和聲明 命名空間的“別名”。比如,上述的控制器中實例化類的代碼可以這樣寫

  1. use Project::Module;  
  2. $user = new Module::User();   
  3. $user->register($register_info);  

甚至

  1. use Project::Module::User as ModuleUser;  
  2. $user = new ModuleUser;   
  3. $user->register($register_info);  

類中的常量也可以通過命名空間訪問,比如上述類中的 STATUS_OK 就可以通過命名空間

  1. Project::Module::User::STATUS_OK  

訪問。進一步的,也可以用別名簡化那麼長的“變量名稱”

  1. use Project::Module::User::STATUS_OK as STATUS_OK;  
  2. echo STATUS_OK;  

順便提下“超空間(The Global Namespace)”的概念。所謂的“超空間”,就是沒有指定命名空間的變量、類和函數。比如

  1. function foo() {  
  2. ...  
  3. }  

這的函數,可以使用 foo() 執行的同時,也可以使用 ::foo(); 這樣執行。

最後,配合使用 autoload 函數即可載入指定命名空間的類。簡單的函數如下

  1. function __autoload( $classname ) {  
  2. $classname = strtolower( $classname );  
  3. $classname = str_replace( '::', DIRECTORY_SEPARATOR, $classname );  
  4. require_once( dirname( __FILE__ ) . '/' . $classname . '.class.php' );  
  5. }  

這樣,比如調用

  1. __autoload('Project::Module::User');  

就可以自動載入 Project_Module_User.class.php 文件(雖然這樣看起來並不方便多少)。


  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved