概述
提出
PHP 在 5.3 后提出了命名空间用来解决组件之间的命名冲突问题,主要参考了文件系统的设计:
- 同一个目录下不允许有相同的文件名 - 同一个命名空间下不允许有相同的类;
- 不同的目录可以有同名文件 - 不同的命名空间可以有相同的类;
定义
使用namespace关键字来定义一个命名空间。其中,顶层命名空间通常为厂商名,不同开发者的厂商命名空间是唯一的。命名空间不需要与文件目录一一对应,但是最好遵守PSR-4规范。
<?php namespace SymfonyComponentHttpFoundation; class Request { } 命名空间必须在所有代码之前声明,唯一的例外就是 declare 关键字。 <?php declare(strict_types=1); namespace App;
命名空间内可包含任意 PHP 代码,但是仅对类 (包括抽象类和 Trait)、接口、函数和常量这四种类型生效。
<?php namespace MyProject; const CONNECT_OK = 1; class FOO {} interface Foo{} function foo() {}
使用
使用use关键字来引入命名空间
<?php namespace App; use SymfonyComponentHttpFoundationRequest; use FooBar; class Test { public function run() { $bar = new Bar(); } }
定义和使用推荐遵循PSR-2的规范
- namespace之后必须存在一个空行;
- 所有use声明必须位于namespace声明之后;
- 每条use声明必须只有一个use关键字。
use语句块之后必须存在一个空行。
当use引入的类出现同名时,可使用as来定义别名
<?php namespace App; use FooBar as BaseBar; class Bar extends BaseBar { }
限定符
除了使用use外,还可以直接使用限定符来进行解析,规则很简单:如果含有前缀则代表从全局命名空间开始解析,否则则代表从当前命名空间开始解析。
<?php namespace App; FooBarfoo(); // 解析成 FooBarfoo(); FooBarfoo(); // 解析成 AppFooBarfoo(); 此规则也适用于函数、常量等 $a = strlen('hi'); // 调用全局函数 strlen $b = INI_ALL; // 访问全局常量 INI_ALL $c = new Exception('error'); // 实例化全局类 Exception
有两个需要特别注意的地方:
对于函数和常量而言,如果当前命名空间不存在,则会自动去全局命名空间去寻找,因此可省略前缀。对于类而言,如果当前命名空间解析不到,不会去全局空间寻找,因此,不可省略
$a = strlen('hi'); $b = INI_ALL; $c = new Exception('error'); // 错误 $c = new Exception('error'); // 正确
当动态调用命名空间时,该命名空间始终会被当成是全局命名空间,因此可以省略前缀
$class1 = 'FooBar'; $object1 = new $class1; // 始终被解析成 FooBar
在内部访问命名空间
PHP 支持两种抽象的访问当前命名空间内部元素的方法,__NAMESPACE__魔术常量和namespace关键字。
__NAMESPACE__常量的值是包含当前命名空间名称的字符串,如果是在全局命名空间,则返回空字符串。
<?php namespace MyProject; function get($classname) { $a = __NAMESPACE__ . '\' . $classname; return new $a; }
关键字namespace可用来显式访问当前命名空间或子命名空间中的元素。它等价于类中的self操作符
namespace App; use blahblah as mine; blahmine(); // Appblahmine() namespaceblahmine(); // Appblahmine() namespacefunc(); // Appfunc() namespacesubfunc(); // Appsubfunc() namespacecname::method(); // Appcname::method() $a = new namespacesubcname(); // Appsubcname $b = namespaceCONSTANT; // AppCONSTANT
转义符号
此外,推荐对所有的进行转义,避免出现不可预期的后果
$class = "dangerousname"; // n 被解析成换行符 $obj = new $class; $class = 'dangerousname'; // 正确,但是不推荐 $class = 'dangerous\name'; // 推荐 $class = "dangerous\name"; // 推荐
以上就是如何理解PHP核心特性命名空间的详细内容,更多关于PHP命名空间的资料请关注靠谱客其它相关文章!
最后
以上就是欣慰期待为你收集整理的如何理解PHP核心特性命名空间的全部内容,希望文章能够帮你解决如何理解PHP核心特性命名空间所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复