C/C++中new/new[]和delete/delete[]的用法比较
2015-06-09 14:38
316 查看
new用法:
1. 开辟单变量地址空间
1)new int; //开辟一个存放数组的存储空间,返回一个指向该存储空间的地址。
int *a = new int 即为将一个int类型的地址赋值给整型指针a。
2)int *a = new int(5) 作用同上,但是同时将整数赋值为5。
2. 开辟数组空间
一维: int *a = new int[100];开辟一个大小为100的整型数组空间。
二维: int **a = new int[5][6]
三维及其以上:依此类推。
一般用法:new 类型 [初值]
delete用法:
1. int *a = new int;
delete a; //释放单个int的空间。
2.int *a = new int[5];
delete [] a; //释放int数组空间。
要访问new所开辟的结构体空间,无法直接通过变量名进行,只能通过赋值的指针进行访问。
用new和C++ delete可以动态开辟,撤销地址空间。在编程序时,若用完一个变量(一般是暂时存储的数组),下次需要再用,但却又想省去重新初始化的功夫,可以在每次开始使用时开辟一个空间,在用完后撤销它。
用法比较:
C++告诉我们在回收用 new 分配的单个对象的内存空间的时候用 delete,回收用 new[] 分配的一组对象的内存空间的时候用delete[]。
关于 new[] 和 delete[],其中又分为两种情况:(1) 为基本数据类型分配和回收空间;(2) 为自定义类型分配和回收空间。
请看下面的程序。
大家可以自己运行这个程序,看一看 delete p1 和 delete[] p1 的不同结果,我就不在这里贴运行结果了。
从运行结果中我们可以看出,delete p1 在回收空间的过程中,只有 p1[0] 这个对象调用了析构函数,其它对象如 p1[1]、p1[2] 等都没有调用自身的析构函数,这就是问题的症结所在。如果用delete[],则在回收空间之前所有对象都会首先调用自己的析构函数。
基本类型的对象没有析构函数,所以回收基本类型组成的数组空间用 delete 和 delete[] 都是应该可以的;但是对于类对象数组,只能用 delete[]。对于 new 的单个对象,只能用 delete 不能用delete[] 回收空间。
所以一个简单的使用原则就是:new 和 delete、new[] 和 delete[] 对应使用。
From:http://blog.sina.com.cn/s/blog_9ce5a1b5010131nj.html
and http://www.cnblogs.com/charley_yang/archive/2010/12/08/1899982.html
1. 开辟单变量地址空间
1)new int; //开辟一个存放数组的存储空间,返回一个指向该存储空间的地址。
int *a = new int 即为将一个int类型的地址赋值给整型指针a。
2)int *a = new int(5) 作用同上,但是同时将整数赋值为5。
2. 开辟数组空间
一维: int *a = new int[100];开辟一个大小为100的整型数组空间。
二维: int **a = new int[5][6]
三维及其以上:依此类推。
一般用法:new 类型 [初值]
delete用法:
1. int *a = new int;
delete a; //释放单个int的空间。
2.int *a = new int[5];
delete [] a; //释放int数组空间。
要访问new所开辟的结构体空间,无法直接通过变量名进行,只能通过赋值的指针进行访问。
用new和C++ delete可以动态开辟,撤销地址空间。在编程序时,若用完一个变量(一般是暂时存储的数组),下次需要再用,但却又想省去重新初始化的功夫,可以在每次开始使用时开辟一个空间,在用完后撤销它。
用法比较:
C++告诉我们在回收用 new 分配的单个对象的内存空间的时候用 delete,回收用 new[] 分配的一组对象的内存空间的时候用delete[]。
关于 new[] 和 delete[],其中又分为两种情况:(1) 为基本数据类型分配和回收空间;(2) 为自定义类型分配和回收空间。
请看下面的程序。
#include <iostream>; using namespace std; class T { public: T() { cout << "constructor" << endl; } ~T() { cout << "destructor" << endl; } }; int main() { const int NUM = 3; T* p1 = new T[NUM]; cout << hex << p1 << endl; // delete[] p1; delete p1; T* p2 = new T[NUM]; cout << p2 << endl; delete[] p2; }
大家可以自己运行这个程序,看一看 delete p1 和 delete[] p1 的不同结果,我就不在这里贴运行结果了。
从运行结果中我们可以看出,delete p1 在回收空间的过程中,只有 p1[0] 这个对象调用了析构函数,其它对象如 p1[1]、p1[2] 等都没有调用自身的析构函数,这就是问题的症结所在。如果用delete[],则在回收空间之前所有对象都会首先调用自己的析构函数。
基本类型的对象没有析构函数,所以回收基本类型组成的数组空间用 delete 和 delete[] 都是应该可以的;但是对于类对象数组,只能用 delete[]。对于 new 的单个对象,只能用 delete 不能用delete[] 回收空间。
所以一个简单的使用原则就是:new 和 delete、new[] 和 delete[] 对应使用。
From:http://blog.sina.com.cn/s/blog_9ce5a1b5010131nj.html
and http://www.cnblogs.com/charley_yang/archive/2010/12/08/1899982.html
相关文章推荐
- 使用C++实现JNI接口需要注意的事项
- 关于指针的一些事情
- c++ primer 第五版 笔记前言
- share_ptr的几个注意点
- oracle数据库删除数据Delete语句和Truncate语句的使用比较
- some new eigrp feature
- 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的区别
- .net(c#)中的new关键字详细介绍
- SQL Server中的XML数据进行insert、update、delete
- C++联合体转换成C#结构的实现方法
- 浅析drop user与delete from mysql.user的区别
- SQL Server中的XML数据进行insert、update、delete操作实现代码
- Rails Routes中new、collection、member的区别浅析