我很难尝试理解以下代码的输出:
class Bar
{
public function test() {
$this->testPublic();
$this->testPrivate();
}
public function testPublic() {
echo "Bar::testPublic\n";
}
private function testPrivate() {
echo "Bar::testPrivate\n";
}
}
class Foo extends Bar
{
public function testPublic() {
echo "Foo::testPublic\n";
}
private function testPrivate() {
echo "Foo::testPrivate\n";
}
}
$myFoo = new foo();
$myFoo->test();
输出:
Foo::testPublic
Bar::testPrivate
Foo类重写了testPublic()和testPrivate(),并继承了test().当我调用test()时,有一个显式指令包含$this伪变量,因此在创建$myFoo实例后,test()函数的最终调用将是$myFoo-> testPublic()和$myFoo-> testPrivate().第一个输出正如我所料,因为我将testPublic()方法重写为echo Foo :: testPublic.但第二个输出对我来说毫无意义.如果我覆盖testPrivate()方法,为什么Bar :: testPrivate?根据定义,无论如何也不会继承父类的私有方法!这没有道理.为什么父方法被称为???
解决方法:
您的代码的问题是方法Bar :: testPrivate是私有的,因此子类不能覆盖它.对于初学者,我建议您阅读PHP-http://www.php.net/manual/en/language.oop5.visibility.php中的可见性.在那里您将了解到只有公共和受保护的类成员方法/属性可以被覆盖,而私有成员方法/属性不能被覆盖.
举个例子,尝试将Bar :: testPrivate方法的可见性更改为public或protected,而不更改示例代码中的任何其他内容.现在尝试运行测试.怎么了?这个:
PHP Fatal error: Access level to Foo::testPrivate() must be protected (as in class Bar) or weaker
最大的问题是:“为什么?”.好吧,你现在用私有的Foo:testPrivate覆盖了Bar :: testPrivate.这个新的私有方法超出了Bar :: test的范围,因为私有类成员只对其当前类可见,而不是父/子类!
因此,正如您所看到的,OOP为类成员提供了一定量的封装,如果您不花时间去理解它,可能会非常混乱.
标签:php,oop,override,visibility
来源: https://codeday.me/bug/20190831/1772887.html