Klären Sie zunächst die Schlussfolgerung. In PHP zeigt self auf die Klasse, die die aktuell aufgerufene Methode definiert, und static zeigt auf die Klasse, die die aktuelle statische Methode aufruft.
Als nächstes wird ein Beispiel verwendet, um das obige Ergebnis zu beweisen
class A { public static $_a = 'Class A'; public static function echoProperty() { echo self::$_a . PHP_EOL; } } class B extends A { public static $_a = 'Class B'; } $obj = new B(); B::echoProperty();//输出 ‘Class A
Der Grund dafür ist, dass self:: oder __CLASS__ verwendet wird, um statisch auf die aktuelle Klasse zu verweisen Ändern Sie in der Klasse, in der die Methode aufgerufen wird, die Methode echoProperty der Klasse A oben wie folgt:
class A { public static $_a = 'Class A'; public static function echoProperty() { echo static::$_a . PHP_EOL; } } //再次调用B::echoProperty将输出 'CLASS B'
Um zu vermeiden, dass die Unterklasse die Statik der übergeordneten Klasse überschreibt Wie im ersten Beispiel oben zu sehen ist, verwenden Sie nach dem Attribut die geerbte Methode, um weiterhin auf die statischen Attribute der übergeordneten Klasse zuzugreifen. PHP5.3 fügt eine neue Syntax hinzu: späte statische Bindung (späte statische Bindung), wobei das Schlüsselwort static anstelle von verwendet wird Das Schlüsselwort self, sodass static auf get_claimed_class() verweist, gibt dieselbe Klasse zurück, d. h. die Klasse, die aktuell die statische Methode aufruft. Dieses Schlüsselwort gilt auch für den Zugriff auf statische Methoden.
Das folgende Beispiel veranschaulicht den Unterschied zwischen new self() und new static() besser (letzteres verwendet die späte statische Bindung von PHP, um auf die aktuelle Klasse der aufrufenden Methode zu verweisen)
class A { public static function get_self() { return new self(); } public static function get_static() { return new static(); } } class B extends A {} echo get_class(B::get_self()); // A echo get_class(B::get_static()); // B echo get_class(A::get_self()); // A echo get_class(A::get_static()); // A