<form id="hz9zz"></form>
  • <form id="hz9zz"></form>

      <nobr id="hz9zz"></nobr>

      <form id="hz9zz"></form>

    1. 明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

      php完成后期靜態綁定

      [摘要]后期靜態綁定工作原理是存儲了在上一個“非轉發調用”(non-forwarding call)的類名。當進行靜態方法調用時,該類名即為明確指定的那個(通常在 :: 運算符左側部分);當進行非靜態方法調...

      后期靜態綁定工作原理是存儲了在上一個“非轉發調用”(non-forwarding call)的類名。當進行靜態方法調用時,該類名即為明確指定的那個(通常在 :: 運算符左側部分);當進行非靜態方法調用時,即為該對象所屬的類。

      所謂的“轉發調用”(forwarding call)指的是通過以下幾種方式進行的靜態調用:self::parent::,static:: 以及forward_static_call() ?捎 get_called_class()函數來得到被調用的方法所在的類名,static:: 則指出了其范圍。

      self:: 的限制

      使用 self:: 或者 __CLASS__ 對當前類的靜態引用,取決于定義當前方法所在的類:

      例:

      class  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

      static(后期靜態綁定)

      后期靜態綁定本想通過引入一個新的關鍵字表示運行時最初調用的類來繞過限制。簡單地說,這個關鍵字能夠讓你在上述例子中調用 test() 時引用的類是 B 而不是 A。最終決定不引入新的關鍵字,而是使用已經預留的 static 關鍵字。

      例:

      <?phpclass A {
          public static function who() {
              echo __CLASS__;
          }    public static function test() {
              static::who(); // 后期靜態綁定從這里開始
          }
      }class B extends A {
          public static function who() {
              echo __CLASS__;
          }
      }
      
      B::test();?>

      結果:

      B

      static 和 $this 的區別

      在非靜態環境下,所調用的類即為該對象實例所屬的類。由于 $this-> 會在同一作用范圍內嘗試調用私有方法,而 static:: 則可能給出不同結果。另一個區別是 只能用static:: 調用靜態屬性。

      例:調用私有方法

      <?phpclass A {
          private function foo() {
              echo "success!\n";
          }    public function test() {
              $this->foo();        static::foo();
          }
      }class B extends A {
         /* foo() will be copied to B, hence its scope will still be A and
          * the call be successful */}class C extends A {
          private function foo() {
              /* original method is replaced; the scope of the new one is C */
          }
      }$b = new B();$b->test();$c = new C();$c->test();   //fails

      結果:

      success!
      success!
      success!
      Fatal error:  Call to private method C::foo() from context 'A' in /tmp/test.php on line 9

      轉發和非轉發調用

      后期靜態綁定的解析會一直到取得一個完全解析了的靜態調用信息為止。另一方面,如果靜態調用使用 parent:: 或者 self:: 將轉發調用信息。

      例:

      class 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();

      結果:

      ACC

      相關推薦:

      php后期靜態綁定實例詳解

      php靜態綁定詳細講述

      php后靜態綁定的定義和使用方法實例詳解

      以上就是php實現后期靜態綁定的詳細內容,更多請關注php中文網其它相關文章!


      學習教程快速掌握從入門到精通的SQL知識。




      日韩精品一区二区三区高清