C++ delete 和delete[] 的区别
2016-07-08 00:19
369 查看
临睡前突然看到一个问题,C++中 delete和delete[] 两种运算符的区别?
带着这个问题查了相关资料,并做了实验。部分结果参考网上资料,感谢博客:
漫步云端
http://www.cnblogs.com/charley_yang/archive/2010/12/08/1899982.html
C++告诉我们在回收用 new 分配的单个对象的内存空间的时候用 delete,回收用 new[] 分配的一组对象的内存空间的时候用 delete[]。
关于 new[] 和 delete[],其中又分为两种情况:(1) 为基本数据类型分配和回收空间;(2) 为自定义类型分配和回收空间。
运行结果:
delete 和delete[]针对简单类型的数据结构可以通用,如数组,单一变量
e.g.
但是如果针对自定义类型的数据结构如类、结构体、string等类型在回收空间时就需要根据申请时使用的new和new[]对应的操作了。在VS平台下,如果对结构体使用了new[]而释放是对应了delete,运行时会报错。在其他编译环境下,未必会报错,导致只释放了头指针指向的空间,其他空间依然存在,会造成内存泄露的结果。
总的使用原则:new 和 delete、new[] 和 delete[] 对应使用。
带着这个问题查了相关资料,并做了实验。部分结果参考网上资料,感谢博客:
漫步云端
http://www.cnblogs.com/charley_yang/archive/2010/12/08/1899982.html
C++告诉我们在回收用 new 分配的单个对象的内存空间的时候用 delete,回收用 new[] 分配的一组对象的内存空间的时候用 delete[]。
关于 new[] 和 delete[],其中又分为两种情况:(1) 为基本数据类型分配和回收空间;(2) 为自定义类型分配和回收空间。
/* VS2010 win10 64bit */ #include "stdafx.h" #include <iostream> using namespace std; class T { public: T() { cout << "constructor" << endl; } ~T() { cout << "destructor" << endl; } }; int _tmain(int argc, _TCHAR* argv[]) { const int NUM = 3; T* p1 = new T; cout << hex << p1 << endl; delete p1; cout << "-------------" << endl; T* p2 = new T[NUM]; cout << p2 << endl; delete[] p2; system("pause"); return 0; }
运行结果:
delete 和delete[]针对简单类型的数据结构可以通用,如数组,单一变量
e.g.
char *p5 = new char[20]; delete p5;
但是如果针对自定义类型的数据结构如类、结构体、string等类型在回收空间时就需要根据申请时使用的new和new[]对应的操作了。在VS平台下,如果对结构体使用了new[]而释放是对应了delete,运行时会报错。在其他编译环境下,未必会报错,导致只释放了头指针指向的空间,其他空间依然存在,会造成内存泄露的结果。
总的使用原则:new 和 delete、new[] 和 delete[] 对应使用。
相关文章推荐
- 使用C++实现JNI接口需要注意的事项
- 关于指针的一些事情
- c++ primer 第五版 笔记前言
- share_ptr的几个注意点
- IE7降低内存和降低CPU的几个技巧
- oracle数据库删除数据Delete语句和Truncate语句的使用比较
- 如何高效的使用内存
- DOS下内存的配置
- Lua中调用C++函数示例
- Lua教程(一):在C++中嵌入Lua脚本
- Lua教程(二):C++和Lua相互传递数据示例
- XP/win2003下发现1G的内存比512M还慢的解决方法
- delete from 表名与truncate table 表名区别
- drop,truncate与delete的区别
- mysql delete limit 使用方法详解
- mysql之delete删除记录后数据库大小不变
- MySQL DELETE语法使用详细解析
- ORACLE SQL-UPDATE、DELETE、INSERT优化和使用技巧分享
- sqlserver中delete、update中使用表别名和oracle的区别
- 详解SQL中drop、delete和truncate的异同