ホームページ >バックエンド開発 >PHPチュートリアル >遅延静的バインディングについて

遅延静的バインディングについて

WBOY
WBOYオリジナル
2016-06-23 14:02:37884ブラウズ

後期静的バインディングに関する 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();?>

結果は次のとおりです:
A
C
C
parent::foo() と self::foo() が呼び出されるとき、なぜクラス C の who() が呼び出されるのですか?友達、説明してくれて?


ディスカッションへの返信 (解決策)

静的演算子の説明:

後期静的バインディングは、実行時に最初に呼び出されたクラスを表すキーワードを導入することで制限を回避しようとします。
最初に呼び出されるクラスは 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()方法


不正確です、self は依然としてクラス B ですが、foo メソッドをオーバーライドしないため、親クラスの foo メソッドを呼び出しますA.
self が実際にクラス C の場合、self::foo(); を self::who(); に変更してみてください。そうすると C が表示されるはずですが、B が表示されます。これが self と static の違いです。

マニュアルを勉強して明確に言いました、訂正していただきありがとうございます。 -- -------------------

「遅延バインディング」とは、static:: が現在のメソッドが定義されているクラスに解析されず、実際に実行されることを意味します。時間で計算されます。静的メソッドの呼び出し (ただし、それに限定されない) に使用できるため、「静的バインディング」とも呼ばれます。

-----------------------------------------------……

A::foo(); //A はクラス A を参照し、クラス A の foo メソッドと who メソッドにアクセスします
parent::foo(); //クラス B??A の親クラスを呼び出します、そしてTell foo メソッドの元の呼び出し元は C です

self::foo(); //self はメソッドを定義するクラス、つまり B を参照しますが、B は foo メソッドを定義しておらず、元の呼び出し元を渡しますC から上へ、

/ 親クラスの foo メソッドにアクセスし、最後に c の who メソッドにアクセスします


したがって、これは 3 階の質問の答えになります。 who、self は B を参照するため、B には who メソッドがあるため、結果は B になります

parent:: または self:: を使用した静的呼び出しは、元の呼び出し情報を転送します。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。