#includeusing namespace std; class Base { public: Base() { cout << "Base:Constructor" <
运行结果为:
![]()
运行结果大家估计看的出来,当析构函数为非虚函数时,delete tmp的时候,只去调用了基类的析构函数,并没有调用派生类的析构函数。 下面基类的析构函数使用需虚析构试试看结果如何:#includeusing namespace std; class Base { public: Base() { cout << "Base:Constructor" <
运行结果为:
这个时候,函数调用delete tmp的时候,先调用了派生类的析构函数,然后调用了基类的析构函数。
通常情况下,一个类的析构函数中,总是去处理一些需要释放内存资源的工作,而当析构函数没有被正确调用的时候,那么可能会造成本该释放的内存在程序结束的时候不被释放,从而造成内存的泄露。当数据量大的时候可能会造成很大的损失。并且对于一个C++程序员,时刻保证程序不出现内存泄露,使我们必须时刻注意的问题。 综上所述,当我们需要把当前类作为基类使用的时候,我们必须注意析构函数虚化的处理。当然当不做基类的时候,我们可以不去设置虚析构。