PHP 5.3中的命名空间使用方法浅述


  本文标签:PHP 5.3 命名空间

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

  这一特性在 PHP5.0x 时候就提出过,后来被取消并安排在 PHP6 中实现  。而此次又再次“提前”到了 PHP 5.3 发布,可见开发人员对其的重视以及谨慎的态度  。

  官方发布时说明文档的内容可能已过期(documentation maybe out dated),所以在这里简单的说明命名空间的用法:首先是声明一个命名空间,加入了新的关键字 namespace ,其应在类文件的开头

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

  然后在控制器中(可能是其他文件)就可以这样调用

  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 文件(虽然这样看起来并不方便多少)  。