今天在修改一个编辑器插件时总报类不能加载错误,明明加载的地方用if 先判定了改类是否存在。找了老半天后终于找到原来是_autoload 做的怪。
在使用PHP的OO模式开发系统时,通常大家习惯上将每个类的实现都存放在一个单独的文件里,这样会很容易实现对类进行复用,同时将来维护时也很便
利。这也是OO设计的基本思想之一。在PHP5之前,如果需要使用一个类,只需要直接使用include/require将其包含进来即可
test.class.php
{ echo 'www.hzhuti.com;
}
}
?>
load.php
代码如下 复制代码
{ static function loadClass($class_name)
{ $filename = $class_name.".class.php"; if (is_file($filename)) return include_once $filename;
}
} /**
* 设置对象的自动载入
* spl_autoload_register — Register given function as __autoload() implementation*/ spl_autoload_register(array('LOAD', 'loadClass')); $a = new Test();//实现自动加载,很多框架就用这种方法自动加载类?>
__autoload()
在
实际项目中,不可能把所有的类都写在一个 PHP 文件中,当在一个 PHP 文件中需要调用另一个文件中声明的类时,就需要通过 include
把这个文件引入。不过有的时候,在文件众多的项目中,要一一将所需类的文件都 include
进来,一个很大的烦恼是不得不在每个类文件开头写一个长长的包含文件的列表。我们能不能在用到什么类的时候,再把这个类所在的 php 文件导入呢?
为此,PHP 提供了 __autoload() 方法,它会在试图使用尚未被定义的类时自动调用。通过调用此函数,脚本引擎在 PHP 出错失败前有了最后一个机会加载所需的类。
__autoload() 方法接收的一个参数,就是欲加载的类的类名,所以这时候需要类名与文件名对应,如 Person.php ,对应的类名就是 Pserson 。
下面看个完整的实例
class ClassA{ public function __construct(){
echo “ClassA load success!”;
}
} //定义一个类ClassA,文件名为ClassA.phpclass ClassA{ public function __construct(){
echo “ClassA load success!”;
}
} class ClassB extends ClassA { public function __construct(){ //parent::__construct();echo “ClassB load success!”;
}
} //定义一个类ClassB,文件名为ClassB.php,ClassB继承ClassAclass ClassB extends ClassA { public function __construct(){ //parent::__construct();echo “ClassB load success!”;
}
}
定义两个测试用的类之后,我们来编写一个含有__autoload()方法的PHP运行程序文件如下:
function __autoload($classname){
$classpath=”./”.$classname.'.php';
if(file_exists($classpath)){
require_once($classpath);
} else{
echo ‘class file'.$classpath.'not found!';
}
}
$newobj = new ClassA();
$newobj = new ClassB();
正是因为我的系统里引入了_autoload 方法,导致JSON 类加载pear 类失败。