栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > PHP

PHP面向对象-后期静态绑定

PHP 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

PHP面向对象-后期静态绑定

自 PHP 5.3.0 起,PHP 增加了一个叫做后期静态绑定的功能,用于在继承范围内引用静态调用的类。
说明

准确说,后期静态绑定工作原理是存储了在==上一个==“==非转发调用==”(non-forwarding call)的类名。当进行静态方法调用时,该类名即为明确指定的那个(通常在运算符 : : 左侧部分);当进行非静态方法调用时,即为该对象所属的类。

所谓的“转发调用”(forwarding call)指的是通过以下几种方式进行的静态调用:self::,parent::,static:: 以及 forward_static_call()。可用 get_called_class() 函数来得到被调用的方法所在的类名,static:: 则指出了其范围。即在进行静态调用时未指名类名的调用属于转发调用。

非转发调用: 转发调用其实就是明确指定类名的静态调用(foo::bar())和非静态调用($foo->bar())。即明确地指定类名的静态调用和非静态调用

该功能从语言内部角度考虑被命名为“后期静态绑定”。“后期绑定”的意思是说,static:: 不再被解析为定义当前方法所在的类,而是在实际运行时计算的。也可以称之为“静态绑定”,因为它可以用于(但不限于)静态方法的调用。

1.self::限制 (静态方法调用)
使用 self:: 或者 __CLASS__ 对当前类的静态引用,取决于定义当前方法所在的类:
   //解释:定义当前test方法的类为A,所以self代表类A。//输出结果为:A
2.非静态环境下使用 static:: (非静态方法调用)

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

class A {  
    private function foo() {  
        echo "success!n";  
    }  
    public function test() {  
        $this->foo();  
        static::foo();  
    }  
}  
  
class B extends A {  
     }  
  
class C extends A {  
    private function foo() {  
          
    }  
}  
  
$b = new B();  
$b->test();  
$c = new C();  
$c->test();  


get_called_class

get_called_class — 后期静态绑定("Late Static Binding")类的名称

get_called_class();获取静态方法调用的类名。

class A {    private function foo() {        echo  get_called_class() . '
';     }    public function test() {        $this->foo();        static::foo();     } }class B extends A {    }class C extends A {    private function foo() {             } } $b = new B(); $b->test(); $b = new C(); $b->test();//输出结果: B B C
3.转发调用信息

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



作者:PHP的艺术编程
链接:https://www.jianshu.com/p/26c404215728


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/227329.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号