以上例程会输出:
A
后期静态绑定的用法 后期静态绑定本想通过引入一个新的关键字表示运行时最初调用的类来绕过限制。简单地说,这个关键字能够让你在上述例子中调用 test() 时引用的类是 B 而不是 A。最终决定不引入新的关键字,而是使用已经预留的 static 关键字。
Example #2 static:: 简单用法
以上例程会输出:
B
Note: 在非静态环境下,所调用的类即为该对象实例所属的类。由于 $this-> 会在同一作用范围内尝试调用私有方法,而 static:: 则可能给出不同结果。另一个区别是 static:: 只能用于静态属性。
Example #3 非静态环境下使用 static::
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
Note: 后期静态绑定的解析会一直到取得一个完全解析了的静态调用为止。另一方面,如果静态调用使用 parent:: 或者 self:: 将转发调用信息。
Example #4 转发和非转发调用
以上例程会输出:
A
C
C
下面示例分析了基于PHP后期静态绑定功能解决在继承范围内引用静态调用的类。
先看如下代码:
class Person
{
public static function status()
{
self::getStatus();
}
protected static function getStatus()
{
echo "erson is alive";
}
}
class Deceased extends Person
{
protected static function getStatus()
{
echo "erson is deceased";
}
}
Deceased::status(); //Person is alive
很明显,结果不是我们预期的,这是因为self::取决于定义时所在的类,而不是运行中的类。为了解决这个问题,你可能会在继承类中重写status()方法,更好的解决方案是PHP 5.3后添加了后期静态绑定的功能。
代码如下:
class Person
{
public static function status()
{
static::getStatus();
}
protected static function getStatus()
{
echo "erson is alive";
}
}
class Deceased extends Person
{
protected static function getStatus()
{
echo "erson is deceased";
}
}
Deceased::status(); //Person is deceased
可见,static::不在指向当前所在的类,实际上,它是在运行中计算的,强制获取最终类的所有属性。
因此,建议,以后不要再使用self::,使用static:: 补充: 网友帖1
php的后期静态绑定,怎么解释?下面的这幅图输出是A,C,C