1、构造函数生成的顺序:
建立派生类对象时,3种构造函数分别是a(基类的构造函数)、b(成员对象的构造函数)、c(派生类的构造函数)这3种构造函数的调用顺序为: a、b、c。
2、构造函数为什么不能是虚函数?
虚函数对应一个虚表,而且这个虚表存储在对象的内存空间,如果构造函数是虚函数,就需要虚表来调用,但是没有调用构造函数,就没有对象,更没有内存空间,所以说,构造函数不可以是虚函数。
3、析构函数为什么要定义成虚函数?
如果一个基类对象指针指向派生类的对象,如果把基类和派生类的析构函数置为虚函数,则就会调用派生类的析构函数和基类的析构函数(先调派生类的,再调基类的,析构的顺序),但是如果没有设置成虚函数,则就只调用基类的析构了。
代码:
#include <iostream>
using namespace std;
class Person
{
public:
virtual ~Person() //加了virtual,将析构函数声明为虚函数
{
cout << "Person::~Person()" << endl;
}
};
class Student : public Person
{
public:
~Student() // virtual可加可不加
{
cout << "Student::~Student()" << endl;
}
};
int main()
{
Person *pt1 = new Person;
Person *pt2 = new Student; // 用基类的指针指向子类
// Student *pt3 = new Person; // 不能用子类指针指向基类,错误!
Student *pt4 = new Student;
delete pt1;
cout << "*********" << endl;
delete pt2;
cout << "*********" << endl;
delete pt4;
cout << "*********" << endl;
return 0;
}
如果去掉虚关键字,则结果如下:
4、什么类型的成员变量只能在构造函数的初始化列表中进行?
(1)、常量成员(const),因为常量只能初始化不可以赋值,所以必须写在初始化列表中。
(2)、引用类型,引用必须在定义的时候初始化,并且不能重新赋值,所以也要写在初始化列表里面
(3)、类内对象成员,没有默认构造函数的类类型,因为使用初始化列表可以不必调用默认构造函数来初始化,而是直
接调用拷贝构造函数初始化(需要初始化的数据成员是对象)
5、虚函数不可以是内联函数:因为虚函数是要动态绑定,就是要在运行时候处理,而内联函数是在编译时候就处理;
虚函数是非静态函数:因为静态的是属于类的,不是属于对象的,而虚函数就是要被对象操作。