delete void* 释放内存问题(C++)
2015-12-30 13:49
316 查看
有时候我们可能遇到将一个指向一块堆内存的类型指针转为 void* 类型的情况,这时候如果直接 delete void* 会出现什么情况呢?我们先用一段代码说明问题:
class mycalss
{
public:
mycalss() : data(new int[100]){}
~mycalss()
{
delete[] data;
}
private:
int *data;
};
int main()
{
mycalss* pobj = new mycalss;
delete pobj;
return 0;
}
这里,不会有内存泄漏产生,因为 delete pobj 的时候,会先调用 myclass 的析构函数释放掉 sizeof(int) * 100 大小的那块堆内存,进而再释放 sizeof(myclass) 大小的堆内存。再看如下这段代码:
int main()
{
void* pobj = new mycalss;
delete pobj;
return 0;
}
这里,在我的机器上会有400字节的内存泄漏,也就是只释放了 sizeof(myclass) 大小的那块堆内存,而 sizeof(int) * 100 大小的那块并未被释放,为何?因为析构函数未被调用!!!
所以,请记住,永远不要 delete void*,保险起见,即使对于内置类型也请不要这样做!!!
class mycalss
{
public:
mycalss() : data(new int[100]){}
~mycalss()
{
delete[] data;
}
private:
int *data;
};
int main()
{
mycalss* pobj = new mycalss;
delete pobj;
return 0;
}
这里,不会有内存泄漏产生,因为 delete pobj 的时候,会先调用 myclass 的析构函数释放掉 sizeof(int) * 100 大小的那块堆内存,进而再释放 sizeof(myclass) 大小的堆内存。再看如下这段代码:
int main()
{
void* pobj = new mycalss;
delete pobj;
return 0;
}
这里,在我的机器上会有400字节的内存泄漏,也就是只释放了 sizeof(myclass) 大小的那块堆内存,而 sizeof(int) * 100 大小的那块并未被释放,为何?因为析构函数未被调用!!!
所以,请记住,永远不要 delete void*,保险起见,即使对于内置类型也请不要这样做!!!
相关文章推荐
- 使用C++实现JNI接口需要注意的事项
- 关于指针的一些事情
- c++ primer 第五版 笔记前言
- share_ptr的几个注意点
- oracle数据库删除数据Delete语句和Truncate语句的使用比较
- Lua中调用C++函数示例
- Lua教程(一):在C++中嵌入Lua脚本
- Lua教程(二):C++和Lua相互传递数据示例
- delete from 表名与truncate table 表名区别
- drop,truncate与delete的区别
- mysql delete limit 使用方法详解
- MySQL DELETE语法使用详细解析
- ORACLE SQL-UPDATE、DELETE、INSERT优化和使用技巧分享
- sqlserver中delete、update中使用表别名和oracle的区别
- 详解SQL中drop、delete和truncate的异同
- SQL Server中的XML数据进行insert、update、delete
- C++联合体转换成C#结构的实现方法
- 浅析drop user与delete from mysql.user的区别
- SQL Server中的XML数据进行insert、update、delete操作实现代码
- MySQL中UPDATE与DELETE语句的使用教程