PHP面向对象中new self()与 new static()的区别浅析
前言
本文主要跟大家介绍了关于PHP面向对象中newself()与newstatic()的区别,这两个方法new出来的对象有什么区别呢,说白了就是new出来的到底是同一个类实例还是不同的类实例呢?下面话不多说了,来一起看看详细的介绍吧。
区别如下:
首先阐明结论,在PHP中self指向定义了当前被调用方法的类,static指向调用当前静态方法的类。
接下来通过一个例子来证明上面的结果
classA
{
publicstatic$_a='ClassA';
publicstaticfunctionechoProperty()
{
echoself::$_a.PHP_EOL;
}
}
classBextendsA
{
publicstatic$_a='ClassB';
}
$obj=newB();
B::echoProperty();//输出ClassA
之所以会这样是因为使用self::或者__CLASS__对当前类的静态引用,取决于定义被调用方法所在的类,将上面ClassA的方法echoProperty做一下修改变成:
classA
{
publicstatic$_a='ClassA';
publicstaticfunctionechoProperty()
{
echostatic::$_a.PHP_EOL;
}
}
//再次调用B::echoProperty将输出'CLASSB'
为了避免上面第一个例子中看到的子类重写父类的静态属性后,使用继承来的方法仍然访问父类的静态属性,PHP5.3增加了一个新的语法:后期静态绑定(Latestaticbinding),使用static关键字替代self关键字,使得static指向与get_called_class()返回的相同的类,即当前调用静态方法的类,该关键字对于静态方法的访问同样有效。
下面的例子更好的说明了newself()和newstatic()之间的差异(后者使用了PHP的后期静态绑定指向调用方法的当前类)
classA
{
publicstaticfunctionget_self()
{
returnnewself();
}
publicstaticfunctionget_static()
{
returnnewstatic();
}
}
classBextendsA{}
echoget_class(B::get_self());//A
echoget_class(B::get_static());//B
echoget_class(A::get_self());//A
echoget_class(A::get_static());//A
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对毛票票的支持。