new和delete 基类指针指向继承类的对象时,delete的过程
2016-05-21 15:55
363 查看
#include<iostream>
using namespace std;
class A{
public:
A(){cout<<"A被构造\n";}
~A(){cout<<"A被析构\n";}
};
class B:public A
{
public:
B(){cout<<"B被构造\n";}
~B(){cout<<"B被析构\n";}
};
int main()
{
A *p=new B;
delete p;
}
运行结果:
A被构造
B被构造
A被析构
Process returned 0 (0x0) execution time : 0.973 s
Press any key to continue.
关键不在于释放内存,而在于析构对象。
C++ new /delete 除了分配内存外,还自动调用构造函数/析构函数
new 分配内存后,调用构在函数,构造对象
delete 释放内存后,调用析构函数,析构对象。
当然,如果派生类有指针成员,并在构造函数中分配内存,析构函数中释放内存。
那么,如果父类没有把析构函数声明为虚析构函数,
delete 的时候,由于指针类型是父类,对象类型是子类,
那么只调用了父类的析构函数;析构了,子类中的父类子对象(父类部分);
子类的析构函数没有机会调用,子类部分则没有析构。
由于子类部分没有析构,指针成员分配的内存就不会释放。
这样就会造成内存泄露。
如果是子类部分配了其他资源,并在析构函数中释放,则会造成资源泄露。
using namespace std;
class A{
public:
A(){cout<<"A被构造\n";}
~A(){cout<<"A被析构\n";}
};
class B:public A
{
public:
B(){cout<<"B被构造\n";}
~B(){cout<<"B被析构\n";}
};
int main()
{
A *p=new B;
delete p;
}
运行结果:
A被构造
B被构造
A被析构
Process returned 0 (0x0) execution time : 0.973 s
Press any key to continue.
关键不在于释放内存,而在于析构对象。
C++ new /delete 除了分配内存外,还自动调用构造函数/析构函数
new 分配内存后,调用构在函数,构造对象
delete 释放内存后,调用析构函数,析构对象。
当然,如果派生类有指针成员,并在构造函数中分配内存,析构函数中释放内存。
那么,如果父类没有把析构函数声明为虚析构函数,
delete 的时候,由于指针类型是父类,对象类型是子类,
那么只调用了父类的析构函数;析构了,子类中的父类子对象(父类部分);
子类的析构函数没有机会调用,子类部分则没有析构。
由于子类部分没有析构,指针成员分配的内存就不会释放。
这样就会造成内存泄露。
如果是子类部分配了其他资源,并在析构函数中释放,则会造成资源泄露。
相关文章推荐
- c++实现矩阵的余弦相似度
- 学习练习 java面向对象封装汽车
- IIS配置
- Axure 实现数字自动加键功能(点击“+”数字加1,点击“-”数字减1)
- PHP学习笔记——文件操作
- [bzoj3510]首都
- 剑指offer11--让数组变成左边奇数右边偶数
- python输入print直接打印中文乱码问题
- Python 实现粒子滤波
- 集合类知识点细节
- m_hWnd和this指针
- UI基础_UIView
- opencl的c++程序
- PHP.ini中session设置
- 关于自定义PopupWindow里面视图的控制
- js怎样实现继承
- 分享Fresco缓存中的图片
- dup/dup2输出重定向
- 二分查找算法的递归、循环实现及其缺陷
- esp8266-SDK的串口发送和中断接收