flash企业网站,宁波网站推广规划,旅游景点介绍网页设计模板,代码判断网站首先阐明结论#xff0c;在PHP中 self指向定义了当前被调用方法的类#xff0c; static指向调用当前静态方法的类。接下来通过一个例子来证明上面的结果class A{public static $_a Class A;public static function echoProperty(){echo self::$_a . PHP_EOL;}}class B exten…首先阐明结论在PHP中 self指向定义了当前被调用方法的类 static指向调用当前静态方法的类。接下来通过一个例子来证明上面的结果class A{public static $_a Class A;public static function echoProperty(){echo self::$_a . PHP_EOL;}}class B extends A{public static $_a Class B;}$obj new B();B::echoProperty();//输出 Class A之所以会这样是因为使用self:: 或者__CLASS__对当前类的静态引用取决于定义被调用方法所在的类将上面Class A的方法echoProperty做一下修改变成class A{public static $_a Class A;public static function echoProperty(){echo static::$_a . PHP_EOL;}}//再次调用B::echoProperty将输出 CLASS B为了避免上面第一个例子中看到的子类重写父类的静态属性后使用继承来的方法仍然访问父类的静态属性 PHP5.3增加了一个新的语法后期静态绑定(Late static binding), 使用static关键字替代self关键字使得static指向与get_called_class()返回的相同的类即当前调用静态方法的类 该关键字对于静态方法的访问同样有效。下面的例子更好的说明了new self()和new static()之间的差异(后者使用了PHP的后期静态绑定指向调用方法的当前类)class A{public static function get_self(){return new self();}public static function get_static(){return new static();}}class B extends A {}echo get_class(B::get_self()); // Aecho get_class(B::get_static()); // Becho get_class(A::get_self()); // Aecho get_class(A::get_static()); // A