如果没有显式的构造函数,编译器会给一个默认的构造函数,并且该默认的构造函数仅仅在没有显式地声明构造函数情况下创建。
构造原则如下:
1. 如果子类没有定义构造方法,则调用父类的无参数的构造方法。
2. 如果子类定义了构造方法,不论是无参数还是带参数,在创建子类的对象的时候,首先执行父类无参数的构造方法,然后执行自己的构造方法。
3. 在创建子类对象时候,如果子类的构造函数没有显示调用父类的构造函数,则会调用父类的默认无参构造函数。
4. 在创建子类对象时候,如果子类的构造函数没有显示调用父类的构造函数且父类自己提供了无参构造函数,则会调用父类自己的无参构造函数。
5. 在创建子类对象时候,如果子类的构造函数没有显示调用父类的构造函数且父类只定义了自己的有参构造函数,则会出错(如果父类只有有参数的构造方法,则子类必须显示调用此带参构造方法)。
6. 如果子类调用父类带参数的构造方法,需要用初始化父类成员对象的方式;
记住:子类只能在构造对象时才能默认(或者用初始化列表中显示调用“特定父类构造函数”)调用父类的构造函数,在构造完成后不能像调用父类成员函数一样调用父类构造函数,这样保证了父类构造函数只调用一次的原则;
程序:
#include<iostream>
using namespace std;
class Base{
public:
Base(){cout << "none argument !!" << endl;};
Base(int x1) : x(x1){
cout<<"Base x1"<<endl;
};
virtual ~Base(){};
void func(int x){cout << "Base : " << x << endl;};private:
int x;
};
class Derive : public Base {
public:
Derive () : Base(100){};
virtual ~Derive (){};
//该处覆盖了Base的func方法;
// void func(int x){cout << "Base : " << x << endl;};
private:int dint;
};
int main()
{
Derive derive;
Derive::Base(2); //::表示编译期间确定的调用,不是对象的调用,故可以编译通过;
// derive.Base(); //该语句会出错,表示不能继承父类的构造函数,对比下一个语句;
derive.func(2); //该语句可编译通过,表示能继承父类的普通成员函数。
Base *pBase = &derive;
pBase->func(1);
return 0;
}