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