PHP-Kern-detaillierte Erklärung von Klassen und objektorientiertem Code
黄舟
Freigeben: 2023-03-06 13:18:02
Original
1395 Leute haben es durchsucht
Als ich zum ersten Mal mit PHP in Berührung kam, nutzte ich einen prozessorientierten Ansatz, um zum Spaß einige sehr einfache Websites zu erstellen, und schrieb einfach PHP Code-Stapelung, Skalierbarkeit und Wartbarkeit sind so schlecht, dass es äußerst umständlich ist, die Logik zu ändern. Später entdeckte ich, dass PHP objektorientiert ist, und plötzlich hatte ich das Gefühl, dass ich damals noch sehr jung und unwissend war. Schließlich ist PHP in C implementiert, was nicht überraschend ist.
Vorwort:
Von unserem Kontakt PHPDas erste, was uns begegnet, sind Funktionen: Array-Operationsfunktionen, String-Operationsfunktionen, Dateioperationsfunktionen usw.
Diese Funktionen sind die Grundlage für unseren Einsatz von PHP und stellen auch die prozessorientierte Programmierung dar, die PHP seit seiner Geburt unterstützt. Prozessorientiert kapselt Funktionen einzeln und löst Probleme mit einer modularen Idee.
Objektorientierte Programmierung wird ab PHP4 unterstützt. Allerdings ist die objektorientierte Unterstützung von PHP4 nicht perfekt. Ab PHP5 hat PHP ein neues Objektmodell (Objektmodell) eingeführt und viele neue Funktionen hinzugefügt, darunter Zugriffskontrolle, abstrakte und endgültige Klassen, Klassenmethoden, magische Methoden, Schnittstellen, Objektklonen und Typhinweise usw. Und in der kürzlich veröffentlichten PHP5.3-Version gibt es Namespaces, verzögerte statische Bindung und zusätzliche Es gibt zwei magische Methoden __callStatic() und __aufrufen().
Wie wird es also unten in PHP implementiert und wie ist seine Struktur?
Eins. Klassenstruktur
Ein Beispiel für das Zitieren von TIPI:
class ParentClass {
}
interface Ifce {
public function iMethod();
}
final class Tipi extends ParentClass implements Ifce {
public static $sa = 'aaa';
const CA = 'bbb';
public function __constrct() {
}
public function iMethod() {
}
private function _access() {
}
public static function access() {
}
}
Nach dem Login kopieren
Eine übergeordnete Klasse ParentClass, eine Schnittstelle Ifce und eine Unterklasse Tipi werden hier definiert. Die Unterklasse erbt die übergeordnete Klasse ParentClass, implementiert die Schnittstelle Ifce und verfügt über eine statische Variable $sa, eine Klassenkonstante CA, eine öffentliche Methode, eine private Methode und eine öffentliche statische Methode. Wie werden diese Strukturen innerhalb der Zend-Engine implementiert? Wie werden Klassenmethoden und Mitgliedsvariablen gespeichert? Zugriffskontrolle, wie werden statische Mitglieder markiert?
Schauen wir uns zunächst die interne Speicherstruktur der Klasse an:
Anhand einiger Felder der obigen Struktur analysieren wir die Leistung des PHP-Codes am Anfang des Artikels im Kernel. Wie unten gezeigt :
Feldname
Feldbeschreibung
ParentClass-Klasse
Ifce-Schnittstelle
Tipi-Klasse
Name
Klassenname
ParentClass
Ifce
Tipi
Typ
Kategorie
2 (benutzerdefiniert)
2 (benutzerdefiniert)
2 (benutzerdefiniert, 1 ist das vom System erstellte) in der Klasse)
运行程序将报错,违反了第三条:Fatal error: Cannot declare property Tipi::$var final, the final modifier is allowed only for methods and classes in .. 这个错误由zend_do_declare_property函数抛出
Bei direkter Ausführung meldet das Programm einen Fehler: Schwerwiegender Fehler: Zugriffstyp für Schnittstellenmethode Ifce::method() muss in weggelassen werden. Dieser Code entspricht dem Code in der zend_do_begin_function_declaration Funktion.
Vier. Ähnlichkeiten und Unterschiede zwischen Methoden (Funktion) und Funktionen (Methode)
Die Implementierung von Funktionen wurde bereits früher vorgestellt Methoden sind ähnlich: Eine Reihe von Logiken werden zur Ausführung in eine Sammlung eingefügt, es gibt jedoch viele Unterschiede in der Verwendung der beiden. Hier diskutieren wir die Implementierung der beiden. Aus Sicht der Implementierung wird der interne Code beider letztendlich als op_array interpretiert, und es gibt keinen Unterschied in seiner Ausführung (es sei denn, objektspezifische Änderungen oder Methoden wie $this/self werden verwendet) und den Unterschied zwischen den beiden spiegelt sich in den beiden Aspekten wider:
1. Es ist die Umsetzung der Definition (Registrierung); 🎜>
2. Es ist die Umsetzung des Aufrufs
Implementierung der Definitionsmethode (Registrierung) Funktionen und Methoden werden während der Kompilierungsphase in der Variablen „compiler_globals“ registriert und von beiden verwendet Die gleichen Kernel-Verarbeitungsfunktionen zend_do_begin_function_declaration() und zend_do_end_function_declaration() vervollständigen diesen Prozess. Der interne Inhalt der beiden wird schließlich als op_codes-Array interpretiert und gespeichert, aber der „gemountete“ Speicherort nach der Kompilierung ist unterschiedlich, wie unten gezeigt:
Registrierungsort von Funktionen und Methoden in PHP
Implementierung des Aufrufs Methode
Der Unterschied im Definitionsort und in der Natur bestimmt, dass Methoden fortgeschrittener sind als Funktionen Überprüfungsarbeit, Methodenaufrufe haben einen weiteren OPCODE namens ZEND_INIT_METHOD_CALL , Die Funktion besteht darin, die Methode bei „execute_data.fbc“ zu registrieren, und dann können Sie dieselbe Verarbeitungsfunktion
ZEND_DO_FCALL_BY_NAME für die Verarbeitung verwenden.
Das obige ist der detaillierte Inhalt vonPHP-Kern-detaillierte Erklärung von Klassen und objektorientiertem Code. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!
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