C++温故知新4(子类的构造函数)

2019-03-21  本文已影响0人  李相赫的乐芙兰

子类不能继承父类的构造函数,而生成一个对象时,会从最基础的父类开始调用构造函数
有以下几种情况:

  1. 如果子类没有定义构造方法,则调用父类的无参数的构造方法。
class A{
    public:
    A(int v = 1){m_v = v;}
    void Print(){printf("A val = %d\n",m_v);}

    int m_v;
};

class B:public A{
public:
    //B(int v){m_v=v;}

    int m_v;
};

int main(){
    B tmp_b;
    printf("%d\n",tmp_b.m_v);
    tmp_b.Print();
    return 0;
}
情况1.png
  1. 如果子类定义了构造方法,不论是无参数还是带参数,在创建子类的对象的时候,首先执行父类无参数的构造方法,然后执行自己的构造方法。

  2. 在创建子类对象时候,如果子类的构造函数没有显示调用父类的构造函数,则会调用父类的默认无参构造函数。

  3. 在创建子类对象时候,如果子类的构造函数没有显示调用父类的构造函数且父类自己提供了无参构造函数,则会调用父类自己的无参构造函数。

  4. 在创建子类对象时候,如果子类的构造函数没有显示调用父类的构造函数且父类只定义了自己的有参构造函数,则会出错(如果父类只有有参数的构造方法,则子类必须显示调用此带参构造方法)。

class A{
    public:
    A(int v = 1){m_v = v;}
    void Print(){printf("A val = %d\n",m_v);}

    int m_v;
};

class B:public A{
public:
    B(int v){m_v=v;}

    int m_v;
};
编译错误.png
  1. 如果子类调用父类带参数的构造方法,需要用初始化父类成员对象的方式
上一篇 下一篇

猜你喜欢

热点阅读