Änderungen an PHP7 durch den neuen Abstract Syntax Tree (AST)
Der Großteil des Inhalts dieses Artikels basiert auf dem RFC-Dokument von AST: https://wiki.php.net/rfc/abstract_syntax_tree Zum besseren Verständnis werden Auszüge aus dem Quelldokument eingeführt.
In diesem Artikel erfahren Sie nicht, was ein abstrakter Syntaxbaum ist. Sie müssen ihn selbst verstehen. Hier finden Sie nur eine Beschreibung einiger Änderungen, die AST an PHP mit sich bringt.
Neuer Ausführungsprozess
Eine wichtige Änderung im Kern von PHP7 ist die Hinzufügung von AST. In PHP5 ist der Ausführungsprozess von PHP-Skripten zu Opcodes:
1 in dieser Phase generiert.
3. In PHP7 werden Op-Arrays nicht mehr direkt während der Syntaxanalysephase generiert, sondern AST wird zuerst generiert, daher gibt es einen weiteren Schritt im Prozess:
4. lexikalische Scanning-Analyse, Konvertieren der Quelldatei in Token-Stream;
5. Syntaxanalyse, Erstellung eines abstrakten Syntaxbaums aus dem Token-Stream; Baum.
Ausführungszeit und SpeicherverbrauchVon den oben genannten Schritten ist dies ein Schritt mehr als der vorherige Prozess, sodass dies nach gesundem Menschenverstand die Programmausführung erhöht Zeit- und Speicherverbrauch. Tatsächlich hat sich jedoch die Speichernutzung erhöht, die Ausführungszeit jedoch abgenommen. Die folgenden Ergebnisse werden durch das Testen von drei Skripten erzielt: klein (ca. 100 Zeilen Code), mittel (ca. 700 Zeilen) und groß (ca. 2800 Zeilen):
https ://gist.github.com/nikic/289b0c7538b46c2220bc
Ausführungszeit für das 100-fache Kompilieren jeder Datei (beachten Sie, dass die Testergebniszeit des Artikels 14 Jahre beträgt, PHP7 wird auch aufgerufen PHP-NG ):
Speicherspitze in einer einzelnen Kompilierung:
|
php-ng | php-ast | diff | ||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
SMALL | 378kB | 414kB | +9,5% | ||||||||||||||||
MITTEL | 507kB | 643kB | +26,8% | ||||||||||||||||
GROSS | 1084kB | 1857kB | +71,3%
Die Testergebnisse einer einzelnen Kompilierung spiegeln möglicherweise nicht die tatsächliche Verwendung wider. Im Folgenden sind die Ergebnisse eines vollständigen Projekttests mit PhpParser aufgeführt :
php-ng | php-ast | diff | |
---|---|---|---|
ZEIT | 25,5ms | 22,8ms | - 11,8 % |
SPEICHER | 2360 kB | 2482 kB | +5,1 % |
Tests zeigen, dass sich nach der Verwendung von AST die Gesamtausführungszeit des Programms um etwa 10 bis 15 % verbessert, der Speicherverbrauch jedoch auch zunimmt. Der Anstieg ist bei einer einzelnen Zusammenstellung großer Dateien offensichtlich, nicht jedoch bei gesamter Projektausführungsprozess. Sehr ernstes Problem.
Beachten Sie außerdem, dass die oben genannten Ergebnisse alle ohne Opcache gelten. Wenn Opcache in einer Produktionsumgebung aktiviert ist, stellt der Anstieg des Speicherverbrauchs kein großes Problem dar.
Semantische Änderungen
Wenn es sich nur um eine Zeitoptimierung handelt, scheint dies kein ausreichender Grund für die Verwendung von AST zu sein. Tatsächlich basiert die Implementierung von AST nicht auf Überlegungen zur Zeitoptimierung, sondern auf der Lösung von Syntaxproblemen. Werfen wir einen Blick auf einige Änderungen in der Semantik.
Yield erfordert keine Klammern
Wenn Sie Yield in der PHP5-Implementierung in einem Ausdruckskontext verwenden (z. B. auf der rechten Seite eines Zuweisungsausdrucks), werden Sie Sie müssen auf beiden Seiten der Yield-Deklaration Klammern verwenden:
<?php $result = yield fn(); // 不合法的 $result = (yield fn()); // 合法的
Dieses Verhalten ist nur auf die Implementierungsbeschränkungen von PHP5 zurückzuführen. In PHP7 sind Klammern nicht mehr erforderlich. Folgende Schreibmethoden sind also ebenfalls zulässig:
<?php $result = yield; $result = yield $v; $result = yield $k => $v;
Natürlich müssen Sie sich dabei an die Anwendungsszenarien von yield halten.
Klammern haben keinen Einfluss auf das Verhalten
In PHP5 ist ($foo)['bar'] = 'baz' und $foo['bar'] = 'baz „Die Bedeutung der beiden Aussagen ist unterschiedlich. Tatsächlich ist die frühere Schreibweise illegal und Sie erhalten die folgende Fehlermeldung:
<?php ($foo)['bar'] = 'baz'; # PHP Parse error: Syntax error, unexpected '[' on line 1
Aber in PHP7 bedeuten die beiden Schreibweisen dasselbe.
Wenn die Parameter der Funktion in Klammern stehen, gibt es ebenfalls ein Problem mit der Typprüfung. Dieses Problem wurde auch in PHP7 gelöst:
<?php function func() { return []; } function byRef(array &$a) { } byRef((func()));
Der obige Code wird nicht angezeigt PHP5, sofern byRef nicht verwendet wird (func())-Methode, aber in PHP7 tritt der folgende Fehler auf, unabhängig davon, ob auf beiden Seiten von func() Klammern vorhanden sind:
PHP Strict standards: Only variables should be passed by reference ...
Änderungen in der Liste( )
<🎜 Das Verhalten des Schlüsselworts >list hat sich stark verändert. Die Reihenfolge, in der die Liste Variablen Werte zuweist (die Reihenfolge auf der linken und rechten Seite des Gleichheitszeichens gleichzeitig), war früher von rechts nach links, jetzt jedoch von links nach rechts:<?php list($array[], $array[], $array[]) = [1, 2, 3]; var_dump($array); // PHP5: $array = [3, 2, 1] // PHP7: $array = [1, 2, 3] # 注意这里的左右的顺序指的是等号左右同时的顺序, # list($a, $b) = [1, 2] 这种使用中 $a == 1, $b == 2 是没有疑问的。Der Grund für die obige Änderung liegt genau darin, dass im Zuweisungsprozess von PHP5 3 zuerst und 1 zuletzt in das Array eingefügt werden, aber jetzt hat sich die Reihenfolge geändert. Die gleichen Änderungen sind:
<?php $a = [1, 2]; list($a, $b) = $a; // PHP5: $a = 1, $b = 2 // PHP7: $a = 1, $b = null + "Undefined index 1"Dies liegt daran, dass $b im vorherigen Zuweisungsprozess zuerst 2 bekam und dann der Wert von $a 1 wurde, aber jetzt ändert sich $a zuerst wird 1 und ist kein Array mehr, sodass $b null wird. Auf die Liste wird jetzt nur einmal pro Offset zugegriffen:
<?php list(list($a, $b)) = $array; // PHP5: $b = $array[0][1]; $a = $array[0][0]; // PHP7: // 会产生一个中间变量,得到 $array[0] 的值 $_tmp = $array[0]; $a = $_tmp[0]; $b = $_tmp[1];Leere Listenmitglieder sind jetzt vollständig verboten, bisher nur in bestimmten Fällen:
<?php list() = $a; // 不合法 list($b, list()) = $a; // 不合法 foreach ($a as list()) // 不合法 (PHP5 中也不合法)
Die Reihenfolge der Referenz Zuweisung
Die Reihenfolge der Referenzzuweisung erfolgt in PHP5 von rechts nach links und die Gegenwartsform von links nach rechts:<?php $obj = new stdClass; $obj->a = &$obj->b; $obj->b = 1; var_dump($obj); // PHP5: object(stdClass)#1 (2) { ["b"] => &int(1) ["a"] => &int(1) } // PHP7: object(stdClass)#1 (2) { ["a"] => &int(1) ["b"] => &int(1) }
__clone-Methode kann <🎜 direkt aufrufen >Sie können jetzt direkt $obj->__clone() verwenden, um die __clone-Methode aufzurufen. __clone war die einzige magische Methode, deren direkter Aufruf zuvor verboten war:
Fatal error: Cannot call __clone() method on objects - use 'clone $obj' instead in ...Variable Syntaxkonsistenz
AST hat auch einige Syntaxfehler behoben Konsistenzprobleme, diese Probleme wurden in einem anderen RFC angesprochen:
https://wiki.php.net/rfc/uniform_variable_syntax. In der neuen Implementierung die Bedeutung Einige frühere grammatikalische Ausdrücke unterscheiden sich etwas von der aktuellen. Einzelheiten finden Sie in der folgenden Tabelle:
Im Großen und Ganzen ist die vorherige Reihenfolge von rechts nach links, jetzt von links nach links richtig, und folgt gleichzeitig dem Grundsatz, dass Klammern keinen Einfluss auf das Verhalten haben. Diesen komplexen Variablenschreibmethoden muss in der tatsächlichen Entwicklung Aufmerksamkeit geschenkt werden.Expression | PHP5 | PHP7 |
---|---|---|
$$foo['bar']['baz'] |
${$foo['bar']['baz']} |
($$foo)['bar']['baz'] |
$foo->$bar['baz'] |
$foo->{$bar['baz']} |
($foo->$bar)['baz'] |
$foo->$bar['baz']() |
$foo->{$bar['baz']}() |
($foo->$bar)['baz']() |
Foo::$bar['baz']() |
Foo::{$bar['baz']}() |
(Foo::$bar)['baz']() |
Empfohlenes Tutorial: „
PHP7Das obige ist der detaillierte Inhalt vonÄnderungen an PHP7 durch den neuen Abstract Syntax Tree (AST). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undress AI Tool
Ausziehbilder kostenlos

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Es gibt drei gängige Methoden für den PHP -Kommentarcode: 1. Verwenden Sie // oder #, um eine Codezeile zu blockieren, und es wird empfohlen, // zu verwenden. 2. Verwenden Sie /.../, um Codeblöcke mit mehreren Zeilen zu wickeln, die nicht verschachtelt werden können, aber gekreuzt werden können. 3.. Kombinationskenntnisse Kommentare wie die Verwendung / if () {} / Um Logikblöcke zu steuern oder um die Effizienz mit Editor -Verknüpfungsschlüssel zu verbessern, sollten Sie auf die Schließung von Symbolen achten und das Verschachteln bei der Verwendung vermeiden.

Der Schlüssel zum Schreiben von PHP -Kommentaren liegt in der Klärung des Zwecks und der Spezifikationen. Kommentare sollten "Warum" und nicht "was getan" erklären, um Redundanz oder zu Einfachheit zu vermeiden. 1. Verwenden Sie ein einheitliches Format wie Docblock (/*/) für Klassen- und Methodenbeschreibungen, um die Lesbarkeit und die Kompatibilität der Werkzeuge zu verbessern. 2. Betonen Sie die Gründe für die Logik, z. B. warum JS -Sprünge manuell ausgeben müssen. 3. Fügen Sie eine Übersichtsbeschreibung vor komplexem Code hinzu, beschreiben Sie den Prozess in Schritten und helfen Sie, die Gesamtidee zu verstehen. V. Gute Anmerkungen können die Kommunikationskosten senken und die Effizienz der Code -Wartung verbessern.

Toinstallphpquickly, usexampponwindowsorhomebrewonmacos.1.onwindows, download undInstallxampp, SelectComponents, Startapache und PlaceFilesinhtdocscs.2.Anternativ, manuellinstallphpfrfr

Tolearnphpeffectival, startbysettingupalocalerverenVironmentusexs -LikexamppandacodeeditorikevScode.1) InstallxamppForapache, MySQL und Php.SeacodeeditorForsyntaxSupport.3) testyourscludingveliktingveliktelaThbiliodble.Neclyble.NektFile

Der Schlüssel zum Schreiben guter Kommentare besteht darin, "warum" zu erklären, anstatt nur "was getan wurde", um die Lesbarkeit des Codes zu verbessern. 1. Kommentare sollten logische Gründe erklären, wie z. B. Überlegungen für die Wertauswahl oder -verarbeitung; 2. Verwenden Sie Absatzanmerkungen für eine komplexe Logik, um die Gesamtidee von Funktionen oder Algorithmen zusammenzufassen. Fegen regelmäßig Kommentare beibehalten, um die Konsistenz mit dem Code zu gewährleisten, irreführend und gegebenenfalls veraltete Inhalte zu löschen. V.

Kommentare können nicht nachlässig sein, da sie die Gründe für die Existenz des Codes und nicht die Funktionen erklären möchten, z. B. die Kompatibilität mit alten Schnittstellen oder Einschränkungen von Drittanbietern, sonst können Personen, die den Code lesen, nur auf Vermutungen angewiesen. Die Bereiche, die kommentiert werden müssen, umfassen komplexe bedingte Urteile, spezielle Fehlerbehandlungslogik und vorübergehende Bypass -Beschränkungen. Eine praktischere Möglichkeit, Kommentare zu schreiben, besteht darin, Einzelzeilen-Kommentare auszuwählen oder Kommentare basierend auf der Szene zu blockieren. Verwenden Sie Dokumentblock Kommentare, um Parameter zu erläutern und Werte zu Beginn von Funktionen, Klassen und Dateien zurückzugeben, und halten Sie die Kommentare aktualisiert. Für eine komplexe Logik können Sie dem vorherigen eine Zeile hinzufügen, um die Gesamtabsicht zusammenzufassen. Verwenden Sie gleichzeitig keine Kommentare zum Versiegelungscode, sondern verwenden Sie Versionsteuerungswerkzeuge.

PhpblockComentsuEsfulforwritingMulti-linexplanationen, vorübergehend absorbierendeCode und GeneratingDocumentation

Der erste Schritt besteht darin, das integrierte Umgebungspaket XAMPP oder MAMP auszuwählen, um einen lokalen Server zu erstellen. Der zweite Schritt besteht darin, die entsprechende PHP -Version entsprechend den Projektanforderungen auszuwählen und mehrere Versionen zu konfigurieren. Der dritte Schritt besteht darin, VSCODE oder PHPSTORM als Editor auszuwählen und mit Xdebug zu debuggen. Darüber hinaus müssen Sie Komponist, PHP_CODESNIFFER, PHPUNIT und andere Tools installieren, um die Entwicklung zu unterstützen.
