您的当前位置:首页正文

php实现后期静态绑定

来源:我们爱旅游

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

static(后期静态绑定)

后期静态绑定本想通过引入一个新的关键字表示运行时最初调用的类来绕过限制。简单地说,这个关键字能够让你在上述例子中调用 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

static 和 $this 的区别

在非静态环境下,所调用的类即为该对象实例所属的类。由于 $this-> 会在同一作用范围内尝试调用私有方法,而 static:: 则可能给出不同结果。另一个区别是 只能用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 9

转发和非转发调用

后期静态绑定的解析会一直到取得一个完全解析了的静态调用信息为止。另一方面,如果静态调用使用 parent:: 或者 self:: 将转发调用信息。

例:

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();

结果:

ACC