effective c++ 条款7
2015-10-18 20:43
232 查看
1.随着多态基类应该声明一个质virtual析构函数. 假定class由于不管是什么virtual析构函数, 它应该有一个virtual析构函数.
2.classed的设计目的假设不是作为base classed使用, 或不是为了具备多态性, 就不应该声明virtual析构函数.
当不把A类的析构函数定义为 non-virtual 析构函数时, 编译会报错, 例如以下
当定义为virtual析构函数时就能够正常执行.
问题出在 ptr指向的是子类(B类)对象, 而那个对象却经由一个基类(A类)指针被删除, 而基类有一个non-virtual析构函数.
运行时对象的子类成分( 也就是声明于B类内的成员变量j) 没被销毁, 子类的析构函数也未能运行起来. 然而其基类成分一般会被销毁, 于是造成了一个诡异的"局部销毁" 对象.形成了资源泄漏.
不论什么class仅仅要带有virtual 功能几乎确定应该也有virtual 析构函数.
2.classed的设计目的假设不是作为base classed使用, 或不是为了具备多态性, 就不应该声明virtual析构函数.
#include <iostream> using namespace std; class A { private: int i; public: virtual void Display() { cout<<i<<endl; } // virtual ~A() {}; ~A(); A() : i(0) {} }; class B : public A { private: int j; public: void Display() { cout<<j<<endl; } B() : j(1) {} ~B() {} }; iint main() { A *ptr = new B(); ptr->Display(); delete ptr; return 0; }
当不把A类的析构函数定义为 non-virtual 析构函数时, 编译会报错, 例如以下
当定义为virtual析构函数时就能够正常执行.
问题出在 ptr指向的是子类(B类)对象, 而那个对象却经由一个基类(A类)指针被删除, 而基类有一个non-virtual析构函数.
运行时对象的子类成分( 也就是声明于B类内的成员变量j) 没被销毁, 子类的析构函数也未能运行起来. 然而其基类成分一般会被销毁, 于是造成了一个诡异的"局部销毁" 对象.形成了资源泄漏.
不论什么class仅仅要带有virtual 功能几乎确定应该也有virtual 析构函数.
相关文章推荐
- 读书:C和指针14章-预处理器
- 【C语言】++(a++)的写法是错的
- 《C++标准程序库》读书笔记(一)
- 【黑马程序员】C语言字符串指针介绍及使用
- 【黑马程序员】C语言指针函数以及函数指针
- C++的重写和隐藏
- C++中类的构造函数及初始化
- 第十九篇:学习好C++需要的读的书籍
- 第十八篇:C++命名空间
- C++STL学习(6)其他容器(string,array,hashtable等)
- C++递归实现全排列
- 用C++实现二叉树
- C++ Primer 学习笔记_53_类和数据抽象 --友元、static员
- C++ 排序法之冒泡法和选择法 素数,递归调用,用星号(*)打印一个梯形
- C++中的iter_swap函数的应用
- 【转】【C/C++】实现memcpy函数
- 剑指offer第二十一题【栈的压入、弹出序列】c++实现
- Reverse Linked List(C++)
- 【C语言】 杀人凶手问题
- 【黑马训练营】IOS C语言通讯录