Heim  >  Artikel  >  Backend-Entwicklung  >  Detaillierte Erklärung der magischen Methode __autoload() in PHP

Detaillierte Erklärung der magischen Methode __autoload() in PHP

藏色散人
藏色散人Original
2019-07-26 13:51:438047Durchsuche

Dieser Artikel stellt Ihnen die magische Methode __autoload() in PHP vor. Ich hoffe, dass sie Freunden in Not hilfreich sein wird!

__autoload(), versucht eine undefinierte Klasse zu laden

Funktion:

Sie können es aktivieren, indem Sie diese Funktion definieren Automatisches Laden von Klassen.

Bevor die Methode der magischen Funktion __autoload() erschien, mussten Sie, wenn Sie 100 Objekte in einer Programmdatei instanziieren wollten, include oder require verwenden, um 100 Klassendateien einzuschließen, oder Sie müssen diese 100 einschließen. Jede Klasse ist in derselben Klassendatei definiert - ich glaube, diese Datei wird sehr groß sein, und dann werden Sie Schmerzen haben.

Aber mit der Methode __autoload() müssen Sie sich darüber in Zukunft keine Sorgen mehr machen. Diese Klasse lädt die angegebene Datei automatisch, bevor Sie das Objekt instanziieren.

Schauen wir uns das anhand eines Beispiels an:

Schauen wir uns zuerst die alte Methode an:

/** 
 * 文件non_autoload.php 
 */ 
   
require_once('project/class/A.php');  
require_once('project/class/B.php');  
require_once('project/class/C.php');  
   
if (条件A) {  
    $a = new A();  
    $b = new B();  
    $c = new C();  
    // … 业务逻辑  
} else if (条件B) {  
    $a = newA();  
    $b = new B();  
    // … 业务逻辑  
}

Hast du es gesehen? Nicht 100, nur 3 scheinen etwas nervig zu sein. Und es gibt ein Problem: Wenn das Skript den Zweig „Bedingung B“ ausführt, muss die Datei C.php eigentlich nicht eingebunden werden. Denn jede enthaltene Datei, unabhängig davon, ob sie verwendet wird oder nicht, wird von der PHP-Engine kompiliert.

Wenn es nicht verwendet, sondern kompiliert wird, kann dies als Ressourcenverschwendung angesehen werden. Wenn C.php außerdem D.php enthält, enthält D.php E.php. Und in den meisten Fällen wird der „Conditional B“-Zweig ausgeführt, was einige Ressourcen verschwendet, um drei „nutzlose“ Dateien C.php, D.php und E.php zu kompilieren.

Was ist, wenn Sie die Methode __autoload() verwenden?

/** 
 * 文件autoload_demo.php 
 */ 
function  __autoload($className) {  
    $filePath = “project/class/{$className}.php”;  
    if (is_readable($filePath)) {  
        require($filePath);  
    }  
}  
   
if (条件A) {  
    $a = new A();  
    $b = new B();  
    $c = new C();  
    // … 业务逻辑  
} else if (条件B) {  
    $a = newA();  
    $b = new B();  
    // … 业务逻辑  
}

ok, egal wie effizient es ist, zumindest sieht die Schnittstelle viel komfortabler aus, ohne zu viele redundante Codes.

Sehen wir uns hier die Effizienz an:

Wenn die PHP-Engine die Klasse A zum ersten Mal verwendet, sie aber nicht finden kann, ruft sie automatisch die Methode __autoload auf und fügt sie hinzu Der Klasse wird als Parameter der Name „A“ übergeben. Daher müssen wir in __autoload() die entsprechende Datei anhand des Klassennamens finden und einschließen. Wenn unsere Methode sie nicht finden kann, meldet die PHP-Engine einen Fehler.

Hinweis:

Sie können hier nur require verwenden, da die PHP-Engine, sobald sie enthalten ist und erneut auf Klasse A trifft, nicht __autoload, sondern Using aufruft Klasse A direkt im Speicher führt nicht zu mehreren Einschlüssen.

Erweiterung:

Tatsächlich wurde mit der heutigen Entwicklung von PHP „spl_autoload_register“ – das Registrieren einer bestimmten Funktion als Implementierung von __autoload – implementiert, aber das ist so nicht in diesem Artikel enthalten Innerhalb der Erklärung können Sie bei Interesse das Handbuch selbst lesen.

Empfohlenes praktisches PHP-Tutorial: https://www.php.cn/k.html

Das obige ist der detaillierte Inhalt vonDetaillierte Erklärung der magischen Methode __autoload() in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn