先贴上测试代码
<code><?php class A { private $name = 'A'; public function setName($value) { $this->name = $value; echo $this->name; } } class B extends A { public function Name() { $this->setName('abc'); } } $b = new B(); $b->Name();</code>
输出结果是abc,在实例化子类的时候会自动实例化父类吗?如果不自动实例化,那么父类的$name是怎么可以赋值的?
先贴上测试代码
<code><?php class A { private $name = 'A'; public function setName($value) { $this->name = $value; echo $this->name; } } class B extends A { public function Name() { $this->setName('abc'); } } $b = new B(); $b->Name();</code>
输出结果是abc,在实例化子类的时候会自动实例化父类吗?如果不自动实例化,那么父类的$name是怎么可以赋值的?
实名反对楼上答案。
先说结论:
php在继承的时候会继承父类的所有的方法和属性。
由于权限控制,在子类中不能使用父类的私有方法和属性。
但在父类中使用自己的私有属性不受影响。
我们将以上代码修改成这样:
<code class="php"><?php class A { private $name = 'A'; public function setName($value) { $this->name = $value; } } class B extends A { public function Name() { var_dump($this); $this->setName('abc'); var_dump($this); } } $b = new B(); $b->Name(); </code>
输出结果
<code class="php">class B#1 (1) { private $name => string(1) "A" } class B#1 (1) { private $name => string(3) "abc" }</code>
一目了然。
看来类的继承学习的还是不够啊,子类继承父类所有可以被继承的成员属性和成员方法。
调用$b->Name();就是调用类B实例化的对象里面Name成员方法,而父类的setName的方法是被继承下来的。你可以想象一下类B里面已经写了setName这个方法,所以类B可以直接使用$this->setName去调。
再看你的例子,我们知道父类里用private描述的私有成员属性和方法是不会被继承下来的,所以类B里面虽然调用了父类公开的setName方法,但是方法里面修改的 $this->name 实际只是一个新属性,而不是父类里被赋值为'A'这个属性。