delete用于释放单个对象,delete[]用于释放对象数组;误用会导致析构函数未被正确调用或未定义行为,尤其类类型数组将引发内存泄漏,应始终匹配new与delete形式,并优先使用智能指针和容器管理内存。
![C++ delete与delete[]的区别_C++数组内存释放的正确姿势 C++ delete与delete[]的区别_C++数组内存释放的正确姿势](https://seo.sqjnqi.com/wp-content/uploads/2025/12/20251206_6933b0bacccf0.png)
在c++中,delete 和 delete[] 都用于释放动态分配的内存,但它们的使用场景和行为有重要区别。用错会导致未定义行为,比如程序崩溃或内存泄漏。
delete 与 delete[] 的核心区别
delete 用于释放通过 new 分配的单个对象,而 delete[] 用于释放通过 new[] 分配的对象数组。
编译器根据使用的是 delete 还是 delete[] 来决定如何调用析构函数和释放内存:
- 使用 delete 时,只调用单个对象的析构函数。
- 使用 delete[] 时,会依次调用数组中每个对象的析构函数,然后再释放整块内存。
如果对数组使用 delete 而不是 delete[],只有第一个元素的析构函数会被调用,其余对象的资源不会被正确清理,造成资源泄漏。反之,对单个对象使用 delete[] 也是未定义行为。
立即学习“C++免费学习笔记(深入)”;
基本类型的数组:看似安全,实则危险
对于像 int、double 等基本类型,不使用析构函数,所以即使误用 delete 代替 delete[],程序可能仍能运行:
int* arr = new int[10]; delete arr; // 错误!应该用 delete[]
虽然这段代码可能不立即出错,但它仍是未定义行为。不同编译器或运行环境下的表现可能不同,一旦上线就可能引发难以排查的问题。
类类型数组:错误使用后果严重
当数组元素是自定义类类型时,析构函数的调用至关重要。例如:
class MyClass { public: MyClass() { data = new int[100]; } ~MyClass() { delete[] data; } private: int* data; }; <p>MyClass* objs = new MyClass[5]; delete objs; // 严重错误!只调用第一个对象的析构函数</p>
上面代码中,只有第一个 MyClass 对象的析构函数被调用,其余4个对象的 data 指针永远不会被释放,导致内存泄漏。
正确做法是:
delete[] objs; // 正确:所有对象的析构函数都会被调用
正确释放数组内存的建议
为了避免混淆和错误,推荐以下做法:
- 始终成对使用:new ↔ delete,new[] ↔ delete[]。
- 尽量避免手动管理内存,优先使用智能指针(如 std::unique_ptr)和容器(如 std::vector)。
- 对于数组,使用 std::unique_ptr
可自动调用 delete[]:
std::unique_ptr<int[]> arr = std::make_unique<int[]>(10); // 使用完毕后无需手动 delete,离开作用域自动释放
这样既安全又简洁,还能防止忘记释放或误用 delete。
基本上就这些。记住匹配规则,善用现代C++工具,就能避开大多数陷阱。