(注意:如果需要实例化的对象,在本文件中已经找到该类的定义的话,就不会触发 __autoload 函数)
他和 spl_autoload_registe r的区别就在于当文件中同时出现__autoload和spl_autoload_register时,以spl_autoload_register为准
命名空间
我们先前讲过类的自动加载,然后我就在思索。
我们用框架写代码的时候,每在另一个文件中调用其他类时
我们并没有写spl_autoload_register这个方法啊?那我们时怎么实现的呢?
原理
原来啊,我们php在5.3时引入了命名空间的概念(这也是为什么大多数的框架不支持5.3之前的版本原因之一),命名空间大家多少还是了解的吧:不知道的去墙角面壁思过
命名空间简而言之就是一种标识,它的主要目的是解决命名冲突的问题。就像在日常生活中,有很多姓名相同的人,如何区分这些人呢?那就需要加上一些额外的标识。把工作单位当成标识似乎不错,这样就不用担心 “撞名” 的尴尬了。
命名空间分类
- 完全限定命名空间
- 限定命名空间
new 成都\徐大帅(); // 限定类名 new \成都\徐大帅(); // 完全限定类名
在当前命名空间没有声明的情况下,限定类名和完全限定类名是等价的。因为如果不指定空间,则默认为全局()。
namespace 美国; new 成都\徐大帅(); // 美国\成都\徐大帅(实际结果) new \成都\徐大帅(); // 成都\徐大帅(实际结果)
这个例子展示了在命名空间下,使用限定类名和完全限定类名的区别。(完全限定类名 = 当前命名空间 + 限定类名)
/* 导入命名空间 */ use 成都\徐大帅; new 徐大帅(); // 成都\徐大帅(实际结果) /* 设置别名 */ use 成都\徐大帅 AS CEO; new CEO(); // 成都\徐大帅(实际结果) /* 任何情况 */ new \成都\徐大帅();// 成都\徐大帅(实际结果)
使用命名空间只是让类名有了前缀,不容易发生冲突,系统仍然不会进行自动导入。
如果不引入文件,系统会在抛出 "Class Not Found" 错误之前触发 __autoload() 或者spl_autoload_register函数,并将限定类名传入作为参数。
上面的例子都是基于你已经将相关文件手动引入的情况下实现的,否则系统会抛出 " Class '成都徐大帅' not found"。因为她不知道这个文件在哪里。所以在引入命名空间以后又引入了自动加载
接下来,我们就在用命名空间加载我们的 类
一个使用命名空间自动加载类的小实验