C++中delete 和delete[]的区别

简介:   c++告诉我们在回收new分配的单个对象的内存空间的时候用delete,           回收new[ ]分配的一组对象的内存空间的时候用 delete[ ]; 1 #include 2 using namespace std; 3 4 class Father ...

  c++告诉我们在回收new分配的单个对象的内存空间的时候用delete,

          回收new[ ]分配的一组对象的内存空间的时候用 delete[ ];

 1 #include <iostream>
 2 using namespace std;
 3 
 4 class Father
 5 {
 6 public:
 7     virtual ~Father()
 8     {   
 9         cout << "Father's Desconstruct Called. " << endl;
10     }   
11 };
12 
13 class Son: public Father
14 {
15 public:
16     ~Son()
17     {   
18         cout << "Son's Desconstruct Called " << endl;
19     }   
20 
21 };
22 
23 int main()
24 {
25     Son* f = new Son[3];
26     delete  f;  
27 
28     return 0;
29 }
[root@cp ~]# ./test
test/   test11/ test.o  
[root@cp ~]# ./test.o
Son's Desconstruct Called
Father's Desconstruct Called.
*** glibc detected *** ./test.o: munmap_chunk(): invalid pointer: 0x08e5e00c ***
======= Backtrace: =========
/lib/libc.so.6[0x7ace31]
/usr/lib/libstdc++.so.6(_ZdlPv+0x22)[0x1b0552]
./test.o[0x8048998]
./test.o[0x8048830]
/lib/libc.so.6(__libc_start_main+0xe6)[0x752ce6]
./test.o[0x8048731]
======= Memory map: ========
00101000-001e2000 r-xp 00000000 08:06 531428     /usr/lib/libstdc++.so.6.0.13
001e2000-001e6000 r--p 000e0000 08:06 531428     /usr/lib/libstdc++.so.6.0.13

//比较下面代码:

 

 1 #include <iostream>
 2 using namespace std;
 3 
 4 class Father
 5 {
 6 public:
 7     virtual ~Father()
 8     {   
 9         cout << "Father's Desconstruct Called. " << endl;
10     }   
11 };
12 
13 class Son: public Father
14 {
15 public:
16     ~Son()
17     {   
18         cout << "Son's Desconstruct Called " << endl;
19     }   
20 
21 };
22 
23 int main()
24 {
25     Son* f = new Son();
26     delete [] f;
27 
28     return 0;
29 }
[root@cp ~]# g++ test.cpp -o test.o
[root@cp ~]# ./test.o
段错误 (core dumped)
[root@cp ~]#

从运行结果中分析,delete f在回收空间的过程中, (代码一中:)只有f[0]这个对象调用了析构函数,其他对象如:f[1], f[2]并没调用自身的析构函数; 这就是问题的症结所在。如果用 delete[],则在回收空间之前所有对象都会首先调用自己的析构函数。
   基本类型的对象没有析构函数,所以回收基本类型组成的数组空间用 delete 和 delete[] 都是应该可以的;但是对于类对象数组,只能用 delete[]。对于 new 的单个对象,只能用 delete 不能用 delete[] 回收空间。
    所以一个简单的使用原则就是:new 和 delete、new[] 和 delete[] 对应使用。
~                                                                                  

 

 

 

相关文章
|
1月前
|
C++
【C++】深入解析C/C++内存管理:new与delete的使用及原理(二)
【C++】深入解析C/C++内存管理:new与delete的使用及原理
|
1月前
|
编译器 C++ 开发者
【C++】深入解析C/C++内存管理:new与delete的使用及原理(三)
【C++】深入解析C/C++内存管理:new与delete的使用及原理
|
1月前
|
存储 C语言 C++
【C++】深入解析C/C++内存管理:new与delete的使用及原理(一)
【C++】深入解析C/C++内存管理:new与delete的使用及原理
|
12天前
|
存储 安全 编译器
在 C++中,引用和指针的区别
在C++中,引用和指针都是用于间接访问对象的工具,但它们有显著区别。引用是对象的别名,必须在定义时初始化且不可重新绑定;指针是一个变量,可以指向不同对象,也可为空。引用更安全,指针更灵活。
|
1月前
|
C语言 C++
C 语言的关键字 static 和 C++ 的关键字 static 有什么区别
在C语言中,`static`关键字主要用于变量声明,使得该变量的作用域被限制在其被声明的函数内部,且在整个程序运行期间保留其值。而在C++中,除了继承了C的特性外,`static`还可以用于类成员,使该成员被所有类实例共享,同时在类外进行初始化。这使得C++中的`static`具有更广泛的应用场景,不仅限于控制变量的作用域和生存期。
45 10
|
1月前
|
程序员 C语言 C++
C++入门5——C/C++动态内存管理(new与delete)
C++入门5——C/C++动态内存管理(new与delete)
55 1
|
1月前
|
C语言 C++
实现两个变量值的互换[C语言和C++的区别]
实现两个变量值的互换[C语言和C++的区别]
16 0
|
2月前
|
C++
C++(十九)new/delete 重载
本文介绍了C++中`operator new/delete`重载的使用方法,并通过示例代码展示了如何自定义内存分配与释放的行为。重载`new`和`delete`可以实现内存的精细控制,而`new[]`和`delete[]`则用于处理数组的内存管理。不当使用可能导致内存泄漏或错误释放。
|
3月前
|
存储 编译器 C语言
C++内存管理(区别C语言)深度对比
C++内存管理(区别C语言)深度对比
82 5
|
3月前
|
存储 程序员 编译器
c++学习笔记08 内存分区、new和delete的用法
C++内存管理的学习笔记08,介绍了内存分区的概念,包括代码区、全局区、堆区和栈区,以及如何在堆区使用`new`和`delete`进行内存分配和释放。
45 0