static 后期静态绑定
这一点php的文档做了详细的介绍,但是我以前一直很少关注这个地方,基本上都是使用 self:: 的方式进行静态方法与属性的调用。
从php5.3开始,php增加了一个叫后期绑定的功能,用于在继承范围内引用静态调用的类
该功能从语言内部角度考虑北命名为“后期静态绑定”;“后期绑定”意思说:static::不再被解析为定义当前方法所在的类,而是在实际运行时计算的,也可以成为“静态绑定”;因为他可以用于(但不限于静态方法的调用)。
self::的限制 使用self::或者_class_对当前类的静态引用,取决于定义当前方法所在的类
我觉得后期绑定某种程度上,像是静态方法的重载。这里贴出 php 文档中的例子来进行一下讲述
<?php class A { public static function who() { echo __CLASS__; } public static function test() { self::who(); static::who();// 后期静态绑定 } } class B extends A { public static function who() { echo __CLASS__; } }
B::test();
如果是 self::who() 调用,会输出:A。如果是 static::who() 会输出 B
这样来看,是不是相当于 class B重写了父类 A 的 who() 方法?那么如果灵活使用这个特性,可以让 static 具备更强的灵活性。充分发挥其性能优
势,又能解决扩展性差的问题。当然还是一样,要从面向对象的角度出发,一切适可而止。
后期静态绑定的用法
后期静态绑定试图通过引入一个关键字表示运行时最初调用的类来绕过限制。简单的说,这个关键字能够让你在上述中调用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