C++总复习_new&delete
2012-01-11 19:43
330 查看
1.new与malloc的写法及区别
使用malloc函数和new[ ]运算符申请恰好存放100个double型数据的动态内存的写法分别如下:
double *p,*q;
p=(double*)malloc(sizeof(double)*100);
q=new double[100];
可以看出malloc函数申请内存以字节为单位,存放100个double型数据需要sizeof(double)*100个字节的内存;new[ ]运算符申请内存以数据类型为单位,申请存放100个double型内存的表达式为new double[100]。另外,malloc函数以void * 型返回申请内存的首地址,将这个地址存入具体的指针变量(不是void * 型)时需要强制转换数据类型;在new运算符构成的new表达式中,体现了所申请的内存未来存放数据的类型,所以不需要进行类型转换。
new运算符申请供单个变量使用的内存时,可以使用“( )”为申请来的内存指定初始值
例如:
double* q=new double(100);
申请能够存放1个double型数据的内存,并将申请来的内存以double型的格式存入100。
使用new、new[ ]运算符成功申请内存时,系统将做以下3件事情:
1. 分配申请的内存;
2. 根据初始值初始化已分配的内存(对于为自定义类型对象(变量)申请内存的情况,将会在已分配的内存上调用自定义类型某个版本的构造函数,关于自定义类型和构造函数,可参见第4章);
3. 返回已分配的内存的首地址。
使用malloc函数成功申请内存只做了上述3件事情的第1件和第3件,不会初始化分配来的内存(第2件事情)是malloc函数和new运算符申请内存时的最大区别。
2.delete与free的写法及区别
free函数用于释放使用malloc函数申请的动态内存,delete和delete[ ]运算符用于释放使用new、new[ ]运算符申请的动态内存,delete和delete[ ]运算符的操作数是待释放内存的地址(指针)。
使用free函数、delete和delete[ ]运算符释放非动态内存将使程序崩溃。
int a;
int *p=&a;
free(p);//错误,将引起程序崩溃
delete p; //错误,将引起程序崩溃
对于自定义类型来说,new、new[ ]运算符申请内存后,会在该内存上调用自定义类型的构造函数;delete和delete[ ]运算符在释放内存之前,会在该内存上调用自定义类型的析构函数
int *p=new int(100);//p指向单个变量
delete p;//使用delete
p=new int[100];//p指向数组
delete [ ]p;//使用delete [ ]
使用malloc函数和new[ ]运算符申请恰好存放100个double型数据的动态内存的写法分别如下:
double *p,*q;
p=(double*)malloc(sizeof(double)*100);
q=new double[100];
可以看出malloc函数申请内存以字节为单位,存放100个double型数据需要sizeof(double)*100个字节的内存;new[ ]运算符申请内存以数据类型为单位,申请存放100个double型内存的表达式为new double[100]。另外,malloc函数以void * 型返回申请内存的首地址,将这个地址存入具体的指针变量(不是void * 型)时需要强制转换数据类型;在new运算符构成的new表达式中,体现了所申请的内存未来存放数据的类型,所以不需要进行类型转换。
new运算符申请供单个变量使用的内存时,可以使用“( )”为申请来的内存指定初始值
例如:
double* q=new double(100);
申请能够存放1个double型数据的内存,并将申请来的内存以double型的格式存入100。
使用new、new[ ]运算符成功申请内存时,系统将做以下3件事情:
1. 分配申请的内存;
2. 根据初始值初始化已分配的内存(对于为自定义类型对象(变量)申请内存的情况,将会在已分配的内存上调用自定义类型某个版本的构造函数,关于自定义类型和构造函数,可参见第4章);
3. 返回已分配的内存的首地址。
使用malloc函数成功申请内存只做了上述3件事情的第1件和第3件,不会初始化分配来的内存(第2件事情)是malloc函数和new运算符申请内存时的最大区别。
2.delete与free的写法及区别
free函数用于释放使用malloc函数申请的动态内存,delete和delete[ ]运算符用于释放使用new、new[ ]运算符申请的动态内存,delete和delete[ ]运算符的操作数是待释放内存的地址(指针)。
使用free函数、delete和delete[ ]运算符释放非动态内存将使程序崩溃。
int a;
int *p=&a;
free(p);//错误,将引起程序崩溃
delete p; //错误,将引起程序崩溃
对于自定义类型来说,new、new[ ]运算符申请内存后,会在该内存上调用自定义类型的构造函数;delete和delete[ ]运算符在释放内存之前,会在该内存上调用自定义类型的析构函数
int *p=new int(100);//p指向单个变量
delete p;//使用delete
p=new int[100];//p指向数组
delete [ ]p;//使用delete [ ]
相关文章推荐
- C++之动态空间分配与释放:new & delete
- C++ new & delete
- C++ new & delete
- [C++ 学习] C++ Primer 习题 5.30 new & delete 操作符
- C++内存管理基础之new & delete
- C++内存管理基础之new & delete
- C++在堆上申请和释放内存 - new & delete
- C++内存管理基础之new & delete
- C++复习要点总结之四New和delete使用
- 【C++】new delete & new[] delete[]
- C++:new&delete
- C++中new&delete与malloc&free比较
- C++内存管理基础之new & delete
- 浅析C++中的 new 与 delete 操作
- 【转】浅谈 C++ 中的 new/delete 和 new[]/delete[]
- 什么情况下要替换C++自带的new和delete
- C++中的new/delete与operator new/operator delete
- 浅谈 C++ 中的 new/delete 和 new[]/delete[]
- 重载new和delete方法实现C++内存安全
- C++ Memory Management : What is the difference between malloc/free and new/delete?