接下来经由过程一个例子来证实上面的效果
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()); // A echo get_class(B::get_static()); // B echo get_class(A::get_self()); // A echo get_class(A::get_static()); // A
更多PHP相干学问,请接见ki4网!
以上就是PHP面向对象中new self( )和 new static( ) 的区分的细致内容,更多请关注ki4网别的相干文章!