ホームページ >バックエンド開発 >PHPチュートリアル >遅延静的バインディングについて
後期静的バインディングに関する PHP マニュアルを読んでも、元のアドレスは http://cn2.php.net/manual/zh/ language.oop5.late-static-bindings.php です
がまだよくわかりません。
4 番目の例
<?phpclass A { public static function foo() { static::who(); } public static function who() { echo __CLASS__."\n"; }}class B extends A { public static function test() { A::foo(); parent::foo(); self::foo(); } public static function who() { echo __CLASS__."\n"; }}class C extends B { public static function who() { echo __CLASS__."\n"; }}C::test();?>
後期静的バインディングは、実行時に最初に呼び出されたクラスを表すキーワードを導入することで制限を回避しようとします。
最初に呼び出されるクラスは C です
A::foo(); はクラス A のメソッドを呼び出します
self::foo(); // この self::foo(); // この self::foo();理解する? C::test() C は B の test() メソッドを継承します
parent::foo(); // self::who() の代わりに static::who();このメソッドによって呼び出される現在のクラスは、クラス C の foo() メソッドです
おそらく、C の who() メソッドがクラス A で呼び出されない理由をまだ理解していないかもしれません。これは、親の特別な関係によるものです。遅延静的バインディングは、特にサブクラスと親クラスの間で継承されたメソッドの問題を解決するために登場しました。
この概念やシナリオを暗記する必要はありません。静的関数の継承とカバレッジの問題が発生し、それが想像したものと異なることがわかった場合は、静的関数を追加して、成功した場合は再試行します。わかりました。
個人的には、オブジェクト指向言語の機能は比較的パーソナライズされており、基本的なものはカプセル化、ポリモーフィズム、継承にすぎないと感じています。これ以上の変態的な機能は通常は必要ありません。必要な場合は、それも考慮する必要があります。それらが信頼できるかどうか。
マニュアルは非常にわかりやすくありませんか?
「遅延バインディング」とは、 static:: が現在のメソッドが定義されているクラスに解析されなくなり、実際の実行時に計算されることを意味します。静的メソッドの呼び出し (ただし、それに限定されない) に使用できるため、「静的バインディング」とも呼ばれます。
----------------------------------------------- - ------
#1 で述べた小さな問題があります
self::foo(); // 这个self实际上是C类。明白吗? C::test() C继承了B的test()方法
-----------------------------------------------……
A::foo(); //A はクラス A を参照し、クラス A の foo メソッドと who メソッドにアクセスします
parent::foo(); //クラス B??A の親クラスを呼び出します、そしてTell foo メソッドの元の呼び出し元は C です
/ 親クラスの foo メソッドにアクセスし、最後に c の who メソッドにアクセスします
したがって、これは 3 階の質問の答えになります。 who、self は B を参照するため、B には who メソッドがあるため、結果は B になります
parent:: または self:: を使用した静的呼び出しは、元の呼び出し情報を転送します。