本文實例講述了PHP類與對象后期靜態綁定操作。分享給大家供大家參考,具體如下:
做項目是后期靜態綁定非常有用。比如service層單例模式,使用后期靜態綁定就非常好實現。
自 PHP 5.3.0 起,PHP 增加了一個叫做后期靜態綁定的功能,用于在繼承范圍內引用靜態調用的類。
準確說,后期靜態綁定工作原理是存儲了在上一個“非轉發調用”(non-forwarding call)的類名。當進行靜態方法調用時,該類名即為明確指定的那個(通常在 :: 運算符左側部分);當進行非靜態方法調用時,即為該對象所屬的類。所謂的“轉發調用”(forwarding call)指的是通過以下幾種方式進行的靜態調用:self::
,parent::
,static::
以及 forward_static_call()
??捎?nbsp;get_called_class()
函數來得到被調用的方法所在的類名,static:: 則指出了其范圍。
該功能從語言內部角度考慮被命名為“后期靜態綁定”。“后期綁定”的意思是說,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
Note:
在非靜態環境下,所調用的類即為該對象實例所屬的類。由于 $this-> 會在同一作用范圍內嘗試調用私有方法,而 static:: 則可能給出不同結果。另一個區別是 static:: 只能用于靜態屬性。
Example #3 非靜態環境下使用 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 7
Note:
后期靜態綁定的解析會一直到取得一個完全解析了的靜態調用為止。另一方面,如果靜態調用使用 parent::
或者 self::
將轉發調用信息。
Example #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
希望本文所述對大家PHP程序設計有所幫助。
新聞熱點
疑難解答
圖片精選