一、构造函数与析构函数中不可以调用虚函数
1.1、构造函数中不能调用虚函数
从语法上讲,调用完全没有问题。但是,往往不能达到多态的效果
class Base{
public:
Base() {
func();
}
virtual void func(){
cout << "I am Base" << endl;
}
};
class Derived : public Base{
public:
void func() {
cout << "I am Derived" << endl;
}
};
int main()
{
Derived obj; // I am Base
return 0;
}
当创建一个派生类对象时,派生类的构造函数会先调用基类的构造函数,在基类的构造函数执行时,此时的this指针指向的是基类对象,通过this->vptr调用的是基类的虚函数。
1.2、析构函数中不能调用虚函数
从语法上讲调用没有问题,但是在析构函数中调用虚函数,可能会导致非法内存引用问题
#include<iostream>
#include<string.h>
using namespace std;
class Base {
public:
virtual void Display() {
cout << "Base Display" << endl;
}
};
class Derived : public Base {
private:
char *m_pName;
public:
Derived() {
m_pName = new char[10];
strcpy(m_pName, "hello");
}
~Derived() {
Display();
}
void Display() override {
cout << m_pName << endl;
}
};
int main(void)
{
Base *pBase = NULL;
pBase = new Derived;
return 0;
}
实现多态时先定义一个基类指针,基类指针实际指向的是派生类对象。当派生类对象生命周期结束时,会调用派生类的析构函数,如果在派生类的析构函数中调用虚函数,此时调用的是派生类自己的虚函数。当进入到析构函数时,派生类的数据成员都是未定义状态,如果派生类自己的虚函数有访问这些数据成员就会导致内存非法引用问题。