ホームページ >バックエンド開発 >PHPチュートリアル >PHP の autoload() 関数と spl_autoload_register() 関数

PHP の autoload() 関数と spl_autoload_register() 関数

WBOY
WBOYオリジナル
2016-06-20 12:47:53772ブラウズ

__autoload() 関数は、必要なクラスを自動的にロードできます。

使用法:

__autoload() オブジェクトをインスタンス化するときに、関連するファイルが導入されていない場合、このメソッドが自動的に呼び出されます。負荷。

例:

public function __autoload($className){    $actionPath ="E://project/LiB/Action/".$className.".class.php";    if(!file_exists($actionPath))    {        echo $actionPath."路径不存在";    }    require_once($actionPath);}

spl_autoload_register() 関数

関数: カスタムロード関数を登録

たとえば、次のようにロードファイルを定義します。 file() をカスタム読み込み関数として使用しますが、少なくともこの関数を宣言または定義した後、オブジェクトをインスタンス化するときに、プログラムは自動的にloadfile()関数を実行せず、__autoload()関数を自動的に実行します。 spl_autoload_register() 関数を使用すると、オブジェクトをインスタンス化するときにプログラムが自動的にloadfile() 関数を呼び出すことができます。

例:

<?php    class test    {        public function testLoad()        {               echo "这是test类中的testLoad方法";        }    }?><?php    spl_autoload_register(array("AutoLoad", "autoLoadCore"), '', true); //注册自动加载方法        //定义自定义加载函数    public static function autoLoadCore($classname)    {        $classPath =  "E://project/LiB/Action/".$className.".class.php";        if(!file_exists($classPath))        {            echo $classPath."路径不存在";        }        require_once($classPath);    }        $test = new test();    $test->testLoad();?>

結果: これはテスト クラスの testLoad メソッドです。

spl_autoload_register() には 3 つのパラメーターがあります。

Firstそれぞれ: array($classname,$method) は配列です。配列には 2 つの要素があり、最初の要素は自動ロード メソッドが配置されているクラスを表し、2 番目の要素は自動ロード メソッドの関数名を表します。 >

2 つのパラメータ: 登録が成功しない場合に例外がスローされるかどうかを示します。true/false

3 番目のパラメータ: true/false、関数をオートローディング関数の先頭に登録するかどうかを示します。列。

注: 1. spl_autoload_register() は実際には自動ロード関数のキューを作成し、定義された順序で 1 つずつ実行されます (これまでのところ、1 つずつ実行する関数を正常に実装できていません)アドバイスをお願いします)

2. spl_autoload_register() を使用して新しいオートロード関数を登録すると、元の __autoload() 関数が無効になります。 __autoload() 関数を使用する必要がある場合は、 spl_autoload_register() を通じて __autoload() 関数を再度登録する必要があります。この関数

を使用できます。
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。