PHP实例化子类会自动实例化父类吗?
天蓬老师
天蓬老师 2017-04-11 09:06:56
0
3
867

先贴上测试代码

<?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();

输出结果是abc,在实例化子类的时候会自动实例化父类吗?如果不自动实例化,那么父类的$name是怎么可以赋值的?

天蓬老师
天蓬老师

欢迎选择我的课程,让我们一起见证您的进步~~

répondre à tous(3)
小葫芦

实名反对楼上答案。
先说结论:

  1. php在继承的时候会继承父类的所有的方法和属性。

  2. 由于权限控制,在子类中不能使用父类的私有方法和属性。

  3. 但在父类中使用自己的私有属性不受影响。


证明

我们将以上代码修改成这样:

<?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();

输出结果

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'这个属性。

Peter_Zhu

子类中$this->setName('abc');的时候将继承下来的这个变量复本重写了

Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal