1. 在构造派生类对象时,先构造基类部分,最后构造派生类部分
我们知道,构造函数的初始化列表的执行先于构造函数体内代码的执行。
我们要想在构造派生类之前将基类构造好,那么就必须将基类的构造放在派生类对象的构造函数的初始化列表中。
class Base {
public:
Base(int data) :ma(data) { cout << "Base(int data)" << endl; }
~Base() { cout << "~Base()" << endl; }
protected:
int ma;
};
class Deriver :public Base {
public:
Deriver(int data) :mb(data), Base(data) { cout << "Deriver(int data)" << endl; }
~Deriver() { cout << "~Deriver()" << endl; }
private:
int mb;
};
2. 如果没有在派生类的构造函数中指定基类的构造方式,那么编译器会去找基类的默认构造方式(默认构造函数),如果没有找到,编译将出错
class Base {
public:
Base(int data) :ma(data) { cout << "Base(int data)" << endl; }
~Base() { cout << "~Base()" << endl; }
//要求编译器生成默认无参的构造函数
Base() = default;
protected:
int ma;
};
class Deriver :public Base {
public:
Deriver(int data) :mb(data) { cout << "Deriver(int data)" << endl; }
~Deriver() { cout << "~Deriver()" << endl; }
private:
int mb;
};
这段代码能编译通过是因为我们使用=default
将编译器自动生成的无参构造函数保留下来了,这样编译时编译器就可以找到编译器生成的默认构造函数。
3. 派生类的构造和析构过程
是一个入栈、出栈的顺序:
Base(int data)
Deriver(int data)
~Deriver()
~Base()
4. 基类中含有一个成员对象,构造顺序如何?
先构造成员对象,然后构造基类对象,最后构造派生类对象:
class A {
public:
A(){ cout << "A()" << endl; }
~A(){ cout << "~A()" << endl; }
};
class Base {
public:
Base(int data) :ma(data) { cout << "Base(int data)" << endl; }
~Base() { cout << "~Base()" << endl; }
Base() = default;
protected:
int ma;
A a; /成员对象
};
class Deriver :public Base {
public:
Deriver(int data) :mb(data), Base(data) { cout << "Deriver(int data)" << endl; }
~Deriver() { cout << "~Deriver()" << endl; }
private:
int mb;
};