提出

在命名空间提出之前,不同的组件很容易碰到命名的冲突,例如 Request 、Response 等常见的命名。PHP 在 5.3 后提出了命名空间用来解决组件之间的命名冲突问题,主要参考了文件系统的设计:

  • 同一个目录下不允许有相同的文件名 - 同一个命名空间下不允许有相同的类;
  • 不同的目录可以有同名文件 - 不同的命名空间可以有相同的类;
 

定义

使用 namespace 关键字来定义一个命名空间。其中,顶层命名空间通常为厂商名,不同开发者的厂商命名空间是唯一的。命名空间不需要与文件目录一一对应,但是最好遵守 PSR-4 规范。

 <?php

 namespace Symfony\Component\HttpFoundation;

 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 Symfony\Component\HttpFoundation\Request;
use Foo\Bar; class Test {
public function run()
{
$bar = new Bar();
}
}

定义和使用推荐遵循 PSR-2 的规范

  • namespace 之后必须存在一个空行;
  • 所有 use 声明必须位于 namespace 声明之后;
  • 每条 use 声明必须只有一个 use 关键字。
    use 语句块之后必须存在一个空行。

当 use 引入的类出现同名时,可使用 as 来定义别名

 <?php

 namespace App;

 use Foo\Bar as BaseBar;

 class Bar extends BaseBar {

 }
 

限定符

除了使用 use 外,还可以直接使用 \ 限定符来进行解析,规则很简单:如果含有 \ 前缀则代表从全局命名空间开始解析,否则则代表从当前命名空间开始解析。

 <?php

 namespace App;

 \Foo\Bar\foo();  // 解析成 \Foo\Bar\foo();
Foo\Bar\foo(); // 解析成 App\Foo\Bar\foo();
此规则也适用于函数、常量等 $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 = 'Foo\Bar';
$object1 = new $class1; // 始终被解析成 \Foo\Bar
 

在内部访问命名空间

PHP 支持两种抽象的访问当前命名空间内部元素的方法,__NAMESPACE__ 魔术常量和 namespace 关键字。

__NAMESPACE__ 常量的值是包含当前命名空间名称的字符串,如果是在全局命名空间,则返回空字符串。

 <?php
namespace MyProject; function get($classname)
{
$a = __NAMESPACE__ . '\\' . $classname;
return new $a;
}

关键字 namespace 可用来显式访问当前命名空间或子命名空间中的元素。它等价于类中的 self 操作符

 namespace App;

 use blah\blah as mine; 

 blah\mine(); // App\blah\mine()
namespace\blah\mine(); // App\blah\mine() namespace\func(); // App\func()
namespace\sub\func(); // App\sub\func()
namespace\cname::method(); // App\cname::method()
$a = new namespace\sub\cname(); // App\sub\cname
$b = namespace\CONSTANT; // App\CONSTANT
 

转义 \ 符号

此外,推荐对所有的 \ 进行转义,避免出现不可预期的后果

 $class = "dangerous\name"; // \n 被解析成换行符
$obj = new $class; $class = 'dangerous\name'; // 正确,但是不推荐
$class = 'dangerous\\name'; // 推荐
$class = "dangerous\\name"; // 推荐

PHP 核心特性 - 命名空间的更多相关文章

  1. Java Gradle入门指南之gretty插件(安装、命令与核心特性)

        Java Web应用开发时常使用Gradle来进行项目管理,可以十分便利地解决包依赖等问题.war插件的出现,让项目部署成为一个复制粘贴的过程,那有没有办法让Java web应用的部署,就像w ...

  2. angularJS的核心特性

    前几天师傅让我了解一下angularJS,angularJS是一个前端框架,具体的优缺点和运用场景我现在也还没有搞清楚,暂时就先不做描述了,留到运用以后进行补充吧. angularJS四大核心特性:M ...

  3. 关于AngularJS学习整理---核心特性

    接触.学习AngularJS已经三个多月了,随着学习的深入,有些东西刚开始不明白,现在开始慢慢明白起来.于是,开始整理这几个月的学习成果.要不又要忘了...  初学Angular,是看到慕课网大漠穷秋 ...

  4. ES6核心特性

    摘要:聊JS离不开ES6啊! 原文:ES6核心特性 作者:ljianshu 前言 ES6 虽提供了许多新特性,但我们实际工作中用到频率较高并不多,根据二八法则,我们应该用百分之八十的精力和时间,好好专 ...

  5. Angular四大核心特性

    Angular四大核心特性 Angular四大核心特性理论概述 MVC模式:它目的是为了分离视图.模型和控制器而设计出来的:其中数据模型用来储存数据,视图用来向用户展示应用程序,控制器充当模型和视图之 ...

  6. angular学习笔记(1)- 四大核心特性

    angular1学习笔记(1) -  angular1四大核心特性 1.MVC model:数据模型层 controller:业务逻辑和控制逻辑 view:视图层,负责展示 2.模块化 Module ...

  7. Zookeeper系列2 原生API 以及核心特性watcher

    原生API 增删改查询 public class ZkBaseTest { static final String CONNECT_ADDR = "192.168.0.120"; ...

  8. AngularJS核心特性(四大点)

    本人刚刚接触AngularJS,还不太熟悉,就说说我目前遇到的一些注意点吧. 1.调用外来文件script文件 AngularJS核心特性一  MVC MVC设计模式 html文件 <!DOCT ...

  9. 乐字节-Java8核心特性实战之Stream(流)

    说起流,我们会想起手机 ,电脑组装流水线,物流仓库商品包装流水线等等.如果把手机 ,电脑,包裹看做最终结果的话,那么加工商品前的各种零部件就可以看做数据源,而中间一系列的加工作业操作,就可以看做流的处 ...

随机推荐

  1. AutoCAD 2019 for mac 非常好用的CAD三维设计绘图软件

    macOS下用什么cad软件?mac在哪下载cad软件? AutoCAD 2019 for mac 是一款非常好用的CAD三维设计绘图软件,可应用三维建模.CAD.渲染.动画.视觉特效和数字图像. A ...

  2. CTF-SSH服务渗透

    环境 Kali ip 192.168.56.102 Smb 靶机ip 192.168.56.101 0x01信息探测 首页发现有类似用户名的信息 先记录下来 Martin N Hadi M Jimmy ...

  3. vue-router之to属性赋值

    to属性赋值 <!-- html --> <div id="app"> <router-link to="/bj/朝阳区"> ...

  4. Linux的一些常用命令(一)

    linux 快捷键1.ls 列出本地址上文件, -a 列出所有(包括隐藏文件) -l 按照列表方式显示 -t 按照时间方式排序 2.touch 创建文件 3.  echo 'abc' > 文件名 ...

  5. .NetCore——中小企业架构及通用权限管理系统开篇

    博客开通已经7年多了,也没写过什么东西,最近,突然想记录下自己的软件开发生涯,于是,找回账户,登录一看,还是当时还是在学校的时候学习的时候记录过一个sql批量到数据的Demo,近两年来,微服务架构火起 ...

  6. vue element NavMenu 莫名出现蓝色边框

    最近在开发一款官网,使用的是element,在头菜单NavMenu,的时候没有设置任何的边框属性,结果出现了如下图所示的边框线. 点击有二级菜单时出现 找了好多方法发现是有一个属性影响到了,:focu ...

  7. 阿里巴巴开源故障注入工具_chaosblade

    chaosblade是阿里巴巴最近开源的一款故障注入的工具,因为我最近在做公司的虚拟化平台的可靠性测试工具,无意中发现这个工具,个人感觉比较有用,用起来也比较简单,所以拿出来分享一下,期望对大家的工作 ...

  8. day27作业

    FTP需求 客户端可以注册登录 client:输入一个login sever:执行login 客户端登陆后可以选择文件夹上传与下载 client:输入一个upload,download sever:执 ...

  9. java入门到秃路线导航,元芳你怎么看?【教学视频+博客+书籍整理】

    目录 一.Java基础 二.关于JavaWeb基础 三.关于数据库 四.关于ssm框架 五.关于数据结构与算法 六.关于开发工具idea 七.关于项目管理工具Mawen.Git.SVN.Gradle. ...

  10. vue-route动态路由

    配置子路由: 路由的视图都需要使用view-router 子路由也可以嵌套路由使用: children来做嵌套如上图 使用location.页面name就可以做页面跳转 mounted:挂载,延迟跳转 ...