在说明名称解析规则之前,我们先看一些重要的定义:
名称中不包含命名空间分隔符的标识符,例如 Foo
名称中含有命名空间分隔符的标识符,例如 FooBar
名称中包含命名空间分隔符,并以命名空间分隔符开始的标识符,例如 FooBar。 namespaceFoo 也是一个完全限定名称。
名称解析遵循下列规则:
Example #1 名称解析示例
<?php
namespace A;
use BD, CE as F;
// 函数调用
foo(); // 首先尝试调用定义在命名空间"A"中的函数foo()
// 再尝试调用全局函数 "foo"
foo(); // 调用全局空间函数 "foo"
myfoo(); // 调用定义在命名空间"Amy"中函数 "foo"
F(); // 首先尝试调用定义在命名空间"A"中的函数 "F"
// 再尝试调用全局函数 "F"
// 类引用
new B(); // 创建命名空间 "A" 中定义的类 "B" 的一个对象
// 如果未找到,则尝试自动装载类 "AB"
new D(); // 使用导入规则,创建命名空间 "B" 中定义的类 "D" 的一个对象
// 如果未找到,则尝试自动装载类 "BD"
new F(); // 使用导入规则,创建命名空间 "C" 中定义的类 "E" 的一个对象
// 如果未找到,则尝试自动装载类 "CE"
new B(); // 创建定义在全局空间中的类 "B" 的一个对象
// 如果未发现,则尝试自动装载类 "B"
new D(); // 创建定义在全局空间中的类 "D" 的一个对象
// 如果未发现,则尝试自动装载类 "D"
new F(); // 创建定义在全局空间中的类 "F" 的一个对象
// 如果未发现,则尝试自动装载类 "F"
// 调用另一个命名空间中的静态方法或命名空间函数
Bfoo(); // 调用命名空间 "AB" 中函数 "foo"
B::foo(); // 调用命名空间 "A" 中定义的类 "B" 的 "foo" 方法
// 如果未找到类 "AB" ,则尝试自动装载类 "AB"
D::foo(); // 使用导入规则,调用命名空间 "B" 中定义的类 "D" 的 "foo" 方法
// 如果类 "BD" 未找到,则尝试自动装载类 "BD"
Bfoo(); // 调用命名空间 "B" 中的函数 "foo"
B::foo(); // 调用全局空间中的类 "B" 的 "foo" 方法
// 如果类 "B" 未找到,则尝试自动装载类 "B"
// 当前命名空间中的静态方法或函数
AB::foo(); // 调用命名空间 "AA" 中定义的类 "B" 的 "foo" 方法
// 如果类 "AAB" 未找到,则尝试自动装载类 "AAB"
AB::foo(); // 调用命名空间 "AB" 中定义的类 "B" 的 "foo" 方法
// 如果类 "AB" 未找到,则尝试自动装载类 "AB"
?>