使用new[]分配的数组必须用delete[]释放,否则会导致未定义行为。正确配对可确保析构函数被调用并防止内存泄漏。
![c++数组内存释放 delete[]正确使用](https://img.php.cn/upload/article/000/969/633/175755919043940.png)
在C++中,使用
new[]动态分配数组内存时,必须用
delete[]来释放,否则会导致未定义行为,常见问题包括内存泄漏、程序崩溃或运行异常。
正确配对 new[] 和 delete[]
当你用
new[]申请一段数组内存,必须用
delete[]释放,不能使用普通的
delete。
new int[10]
→ 必须用delete[]
new char[256]
→ 必须用delete[]
new MyClass[5]
→ 必须用delete[]
错误示例:
int* arr = new int[10]; delete arr; // 错误!应使用 delete[]
这可能导致析构函数未被正确调用(对类类型),或内存管理器混乱,最终引发崩溃。
立即学习“C++免费学习笔记(深入)”;
delete[] 的作用机制
delete[]不仅释放内存,还会对数组中每一个元素调用析构函数(如果是类对象),然后归还整块内存。
例如:
class MyClass {
public:
MyClass() { cout << "构造\n"; }
~MyClass() { cout << "析构\n"; }
};
MyClass* objs = new MyClass[3]; // 构造3次
delete[] objs; // 析构3次,释放内存
如果误用
delete,可能只调用第一个元素的析构函数,其余对象资源未清理,造成资源泄漏。
基本类型也要用 delete[]
即使数组元素是
int、
char等基本类型,也推荐使用
delete[]。虽然对内置类型不调用析构函数,但C++标准要求配对使用,确保可移植性和一致性。
正确写法:
int* p = new int[100]; // ... 使用 delete[] p; // 正确释放 p = nullptr; // 避免悬空指针
避免重复释放和空指针检查
同一块内存不能多次释放,否则导致未定义行为。
释放后建议将指针设为
nullptr,再次
delete[]空指针是安全的:
delete[] p; p = nullptr; delete[] p; // 安全,无操作
但不要重复释放非空指针。
基本上就这些。只要记住:new[] 配 delete[],new 配 delete,就能避免大多数问题。










