PHP の遅延静的バインディングを理解する
PHP では、遅延静的バインディングにより、継承とクラス参照を処理する独自の方法が導入されます。 self キーワードが呼び出されるクラスに解決される従来の継承とは異なり、遅延静的バインディングはこの動作を変更して、self が常に実際のランタイム クラスを指すようにします。
遅延静的バインディングの必要性バインディング
従来、PHP 継承の self キーワードは、子で使用されたか親で使用されたかに関係なく、現在のクラスを参照していました。 クラス。これにより、親クラスから継承したメソッドを呼び出すときに予期しない結果が生じる可能性があります。
たとえば、メソッド foo() を持つ親クラス Parent と、このメソッドをオーバーライドする子クラス Child について考えてみましょう。 Child が self::foo() を呼び出す場合、それ自体の foo() メソッドではなく、Parent クラスの foo() メソッドが呼び出されます。
Late Static Binding の紹介
最新の静的バインディングでは、static キーワードの新しい使用方法を導入することで、この問題に対処しています。 static を使用すると、最初に宣言されたランタイム クラスにバインドされます。これにより、子クラスから呼び出された場合でも、self が常に正しいクラスに解決されることが保証されます。
重要な概念
要約すると、遅延静的バインディングには以下が含まれます。
違いを理解する
違いを説明するには、次のように考えます。次の例:
class Parent { public static function foo() { echo 'Parent::foo() called' . PHP_EOL; } } class Child extends Parent { public static function foo() { echo 'Child::foo() called' . PHP_EOL; } } Parent::foo(); // Outputs 'Parent::foo() called' Child::foo(); // Outputs 'Child::foo() called'
ご覧のとおり、Child 内で self を使用すると、通常は Parent::foo() が呼び出されます。ただし、遅延静的バインディングでは、static により self::foo() が常に正しい Child クラスを参照することが保証されます。
以上がPHP の遅延静的バインディングはどのようにして正確なクラス参照を保証するのでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。