Heim  >  Artikel  >  Backend-Entwicklung  >  [PHP-Klassen und -Objekte] späte statische Bindung

[PHP-Klassen und -Objekte] späte statische Bindung

不言
不言Original
2018-04-17 14:00:461271Durchsuche

Der Inhalt dieses Artikels handelt von [PHP-Klassen und -Objekten], der einen gewissen Referenzwert hat. Jetzt kann ich ihn mit allen teilen, die ihn benötigen

Späte statische Bindung

PHP 5.3.0

Wird verwendet für: Verweise auf statisch aufgerufene Klassen im Vererbungsbereich

Funktionsweise:

  • gespeichert Klassenname des letzten „nicht weiterleitenden Anrufs“.

  • Bei einem statischen Methodenaufruf ist der Klassenname der explizit angegebene (normalerweise auf der linken Seite des ::-Operators); 🎜>Bei einem nicht statischen Methodenaufruf ist es die Klasse, zu der das Objekt gehört.

  • Aufruf weiterleiten: statischer Aufruf über self::, parent::, static::, forward_static_call() (Aufruf einer statischen Methode).

    Sie können die Funktion get_claimed_class() verwenden, um den Klassennamen der aufgerufenen Methode abzurufen, und static:: weist auf deren Gültigkeitsbereich hin.
Diese Funktion wird aus sprachinterner Sicht als „späte statische Bindung“ bezeichnet.

„Late binding“ bedeutet, dass static:: nicht mehr in die Klasse geparst wird, in der die aktuelle Methode definiert ist, sondern zur tatsächlichen Laufzeit berechnet wird.
Es kann auch als „statische Bindung“ bezeichnet werden, da es für Aufrufe statischer Methoden verwendet werden kann (aber nicht darauf beschränkt ist).



Verwendung der späten statischen Bindung
<?phpclass A {
    public static function who() {
        echo __CLASS__; //返回该类被定义时的名字
    }    public static function test() {
        self::who();
    }
}class B extends A {
    // public static function who() {
    //     echo __CLASS__;
    // }}

B::test();  //A?>

Die späte statische Bindung wollte ursprünglich ein neues Schlüsselwort einführen, um die Klasse darzustellen, die ursprünglich zur Laufzeit aufgerufen wurde, um Einschränkungen zu umgehen . Einfach ausgedrückt ermöglicht Ihnen dieses Schlüsselwort, beim Aufruf von test() im obigen Beispiel auf Klasse B statt auf A zu verweisen. Es wurde schließlich beschlossen, keine neuen Schlüsselwörter einzuführen, sondern das bereits reservierte statische Schlüsselwort zu verwenden.

In einer nicht statischen Umgebung ist die aufgerufene Klasse die Klasse, zu der die Objektinstanz gehört. Da $this-> versucht, die private Methode im selben Bereich aufzurufen, kann static:: zu unterschiedlichen Ergebnissen führen.

Ein weiterer Unterschied besteht darin, dass static:: nur für statische Eigenschaften verwendet werden kann.

Example #2 static:: 简单用法<?phpclass A {
    public static function who() {
        echo __CLASS__;
    }    public static function test() {
        static::who(); // 注意使用static,后期静态绑定从这里开始
    }
}class B extends A {
    public static function who() {
        echo __CLASS__;
    }
}

B::test();  //B?>
Späte statische Bindung


PHP 5.3.0

Verwendet für: Verweise auf statisch aufgerufene Klassen im Vererbungsbereich

Funktionsprinzip:

speichert den Klassennamen des vorherigen „nicht weiterleitenden Anrufs“.

  • Bei einem statischen Methodenaufruf ist der Klassenname der explizit angegebene (normalerweise auf der linken Seite des ::-Operators); 🎜>Bei einem nicht statischen Methodenaufruf ist es die Klasse, zu der das Objekt gehört.

  • Aufruf weiterleiten: statischer Aufruf über self::, parent::, static::, forward_static_call() (Aufruf einer statischen Methode).

    Sie können die Funktion get_claimed_class() verwenden, um den Klassennamen der aufgerufenen Methode abzurufen, und static:: weist auf deren Gültigkeitsbereich hin.
  • Diese Funktion wird aus sprachinterner Sicht als „späte statische Bindung“ bezeichnet.

    „Late binding“ bedeutet, dass static:: nicht mehr in die Klasse geparst wird, in der die aktuelle Methode definiert ist, sondern zur tatsächlichen Laufzeit berechnet wird.

    Es kann auch als „statische Bindung“ bezeichnet werden, da es für Aufrufe statischer Methoden verwendet werden kann (aber nicht darauf beschränkt ist).


Verwendung der späten statischen Bindung



Die späte statische Bindung wollte ursprünglich ein neues Schlüsselwort einführen, um die Klasse darzustellen, die ursprünglich zur Laufzeit aufgerufen wurde, um Einschränkungen zu umgehen .

<?phpclass A {
    public static function who() {
        echo __CLASS__; //返回该类被定义时的名字
    }    public static function test() {
        self::who();
    }
}class B extends A {
    // public static function who() {
    //     echo __CLASS__;
    // }}

B::test();  //A?>
Einfach ausgedrückt ermöglicht Ihnen dieses Schlüsselwort, beim Aufruf von test() im obigen Beispiel auf Klasse B statt auf Klasse A zu verweisen. Es wurde schließlich beschlossen, keine neuen Schlüsselwörter einzuführen, sondern das bereits reservierte statische Schlüsselwort zu verwenden.

In einer nicht statischen Umgebung ist die aufgerufene Klasse die Klasse, zu der die Objektinstanz gehört. Da $this-> versucht, die private Methode im selben Bereich aufzurufen, kann static:: zu unterschiedlichen Ergebnissen führen. Ein weiterer Unterschied besteht darin, dass static:: nur für statische Eigenschaften verwendet werden kann.

Verwandte Empfehlungen:

Typbeschränkungen für [PHP-Klassen und -Objekte]
Example #2 static:: 简单用法<?phpclass A {
    public static function who() {
        echo __CLASS__;
    }    public static function test() {
        static::who(); // 注意使用static,后期静态绑定从这里开始
    }
}class B extends A {
    public static function who() {
        echo __CLASS__;
    }
}

B::test();  //B?>


Objektkopie für [PHP-Klassen und -Objekte]

[php-Klassen und -Objekte] magische Methoden

Das obige ist der detaillierte Inhalt von[PHP-Klassen und -Objekte] späte statische Bindung. 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