クラスのオートロード
オートロードを利用しない場合
<?php
include_once('Foo.php')
$foo = new Foo();
- 以上のようにnew Fooする前にinclude_once()でFooクラスを定義したファイルを明示的にinclude()で指定する必要がある。
__autoload()を使ってクラスをオートロードする
<?php
function __autoload($name) {
$file = "${name}.php";
if (is_readable($file)) {
include_once($file);
}
}
$foo = new Foo();
$bar = new Bar();
$baz = new Baz();
- __autoload()関数を定義して、任意のクラスを定義したファイルをinclude()できようにしておく。
- これによってnew Foo()すればFoo.phpが、new Bar()すればBar.phpが自動的にinclude()されて便利。
- ただし、この機能はdeprecateで非推奨になっているので、もう使わない方がよい。
spl_autoload_register()を使ってクラスをオートロードする
<?php
function load($name) {
echo "load($name) was called\n";
if (is_readable("lib/$name.php")) {
include_once("lib/$name.php");
}
}
class Bar {
static function load($name) {
echo "Bar::load($name) was called\n";
if (is_readable("$name.php")) {
include_once("$name.php");
}
}
}
class Baz {
static function load($name) {
echo "Baz::load($name) was called\n";
if (is_readable("ext/$name.php")) {
include_once("ext/$name.php");
}
}
}
spl_autoload_register('load');
spl_autoload_register('Bar::load');
$baz = new Baz();
spl_autoload_register([$baz, 'load']);
$foo = new Foo();
- spl_autoload_register()にクラスをロードするためのロード用関数を指定する。
- __autoload()と違い、ロード用関数を複数指定することができ、new Foo()する際にはFoo.phpが見つかってFooクラスをロードできるまでに、ロード用関数を次々に実行していく。
- ただし、一度Fooクラスが見つかると、残りのロード用関数はもう実行されない。
- また、spl_autoload_register()を使うと、__autoload()関数は実行されなくなる。
- よって、必要ならspl_autoload_register('__autoload')としておけば、これまで通り__autoload()関数を実行できる。
参考