從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關鍵字
例子:
<?php
class 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::將轉發調用信息
<?php
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();
?>
打印結果:
A C C
例子:
<?php
class a {
static public function test() {
print get_called_class();
}
}
class b extends a {
}
a::test();
b::test();
?>
打印結果:
a
b
特別聲明:
get_called_class();獲得類的名稱靜態方法中調用
