本文實例講述了PHP后期靜態綁定。分享給大家供大家參考,具體如下:
從php5.3開始,php增加了一個叫后期綁定的功能,用于在繼承范圍內引用靜態調用的類
該功能從語言內部角度考慮北命名為“后期靜態綁定”;“后期綁定”意思說: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
打印結果:
A
后期靜態綁定的用法
后期靜態綁定試圖通過引入一個關鍵字表示運行時最初調用的類來繞過限制。簡單的說,這個關鍵字能夠讓你在上述中調用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
后期靜態綁定的處理方式解決了以往完全沒有解決的靜態調用,另外一方面,如果靜態調用使用parent::或者self::將轉發調用信息
<?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
例子:
<?phpclass a { static public function test() { print get_called_class(); }}class b extends a {}a::test();b::test();?>
打印結果:
a
b
特別聲明:
get_called_class()
;獲得類的名稱靜態方法中調用
希望本文所述對大家PHP程序設計有所幫助。
新聞熱點
疑難解答
圖片精選