构造函数与析构函数

  • 构造函数不能是虚函数。一般会报错inline”是构造函数的唯一合法存储类。类有一个指向虚函数表的指针用于调用虚函数,这个指针是在构造函数里初始化的,如果构造函数是虚函数,怎么在没有初始化的情况下调用它?

  • 构造函数中最好不要调用虚函数,某些编译器会报错。因为先运行基类构造函数,再运行派生类的。基类的构造函数时已经出现了虚函数表指针,它指向基类的虚函数表,所以基类的构造函数中调用的虚函数是基类的。Effective C++条款9

  • 构造函数和析构函数不能被继承。正因为如此,派生类对象会先调用基类的构造函数,而且只能调用这一次,析构函数也是同理。

  • 类的对象声明会调用构造函数,但类的指针不会。例如MyClass p1, *p2;中p1调用构造函数,p2不会。

  • 析构函数无返回类型,只能有一个,也就不能重载。

  • 析构函数中,delete自身类的对象会导致死循环,堆栈溢出。

虚析构函数

假如一个类没有派生类,那么析构函数可以不是虚函数。如果有派生类,析构函数要声明为虚函数,这是为了防止新手犯错误。如果基类指针指向了派生类的对象,析构时,只会调用基类析构函数,没有派生类的析构函数。

class Base
{
public:
    Base(){ }
    ~Base(){   // 应加上virtual声明
        qDebug()<<"Base destructor";
    }
};

class Derived:public Base
{
public: Derived(){ }
    ~Derived(){
        qDebug()<<"Derived destructor";
    }
};

Base* pBase = new Derived();
delete pBase;

运行结果是Base destructor。给Base类析构函数加上virtual声明后,运行结果:

Derived destructor
Base destructor

一开始我没加virtual,仍然调用了派生类的析构函数,后来发现是基类习惯性继承了QObject类,而后者的析构函数是virtual声明的。于是有结论: 对于继承树,只要在根基类上声明虚析构函数就可以,所有的子类自然继承虚析构函数。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值