加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

PHP后期静态绑定的用处是什么,如何使用?

发布时间:2023-06-09 13:53:39 所属栏目:PHP教程 来源:
导读:这篇文章给大家分享的是PHP后期静态绑定的作用是什么,如何使用?。小编觉得挺实用的,因此分享给大家做个参考,文中的介绍得很详细,而要易于理解和学习,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
这篇文章给大家分享的是PHP后期静态绑定的作用是什么,如何使用?。小编觉得挺实用的,因此分享给大家做个参考,文中的介绍得很详细,而要易于理解和学习,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
 
自 PHP 5.3.0 起,PHP 增加了一个叫做后期静态绑定的功能,用于在继承范围内引用静态调用的类。
 
准确说,后期静态绑定工作原理是存储了在上一个“非转发调用”(non-forwarding call)的类名。当进行静态方法调用时,该类名即为明确指定的那个(通常在 :: 运算符左侧部分);当进行非静态方法调用时,即为该对象所属的类。所谓的“转发调用”(forwarding call)指的是通过以下几种方式进行的静态调用:self::,parent::,static:: 以及forward_static_call()。可用 get_called_class() 函数来得到被调用的方法所在的类名,static:: 则指出了其范围。
 
该功能从语言内部角度考虑被命名为“后期静态绑定”。“后期绑定”的意思是说,static:: 不再被解析为定义当前方法所在的类,而是在实际运行时计算的。也可以称之为“静态绑定”,因为它可以用于(但不限于)静态方法的调用。
 
self:: 的限制
 
使用 self:: 或者 __CLASS__ 对当前类的静态引用,取决于定义当前方法所在的类:
 
Example #1 self:: 用法
 
<?php
 
    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
 
后期静态绑定的用法
 
后期静态绑定本想通过引入一个新的关键字表示运行时最初调用的类来绕过限制。简单地说,这个关键字能够让你在上述例子中调用 test() 时引用的类是 B 而不是 A。最终决定不引入新的关键字,而是使用已经预留的 static 关键字。
 
Example #2 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
 
注意:
 
在非静态环境下,所调用的类即为该对象实例所属的类。由于 $this-> 会在同一作用范围内尝试调用私有方法,而 static:: 则可能给出不同结果。另一个区别是 static::只能用于静态属性。
 
Example #3 非静态环境下使用 static::
 
<?php
 
    class 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
 
Note:
 
后期静态绑定的解析会一直到取得一个完全解析了的静态调用为止。另一方面,如果静态调用使用 parent:: 或者 self:: 将转发调用信息。
 
Example #4 转发和非转发调用
 
<?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
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!