new配对delete,malloc配对free,不可混用;new/delete处理构造与析构,malloc/free仅分配内存;优先使用智能指针和容器避免手动管理。

在C++中,内存释放操作需要根据内存分配方式选择正确的释放方法。new 配对 delete,malloc/calloc/realloc 配对 free,不能混用。正确使用能避免内存泄漏和未定义行为。
new 和 delete 的使用规范
用 new 分配的内存,必须用 delete 释放。对于单个对象:
delete ptr;对于数组,必须使用 delete[]:
delete[] arr;如果用 delete 释放数组,或用 delete[] 释放单个对象,结果是未定义行为。编译器通常无法检查这类错误,容易导致运行时崩溃。
立即学习“C++免费学习笔记(深入)”;
malloc 和 free 的使用规范
来自C语言的 malloc、calloc、realloc 分配的内存,必须用 free 释放:
free(ptr);free 只能用于动态分配的指针,不能用于栈上变量或 nullptr(free(nullptr) 是安全的,但 delete 也可以安全处理 nullptr)。
new/delete 与 malloc/free 不能混用
以下操作是错误的:
- 用 free 释放 new 分配的内存 —— 析构函数不会被调用,资源可能未正确清理
- 用 delete 释放 malloc 分配的内存 —— 可能破坏堆管理结构,导致崩溃
C++ 的 new 不仅分配内存,还会调用构造函数;delete 会先调用析构函数再释放内存。而 malloc/free 只做内存分配和释放,不涉及构造和析构。
实际使用建议
在现代C++中,应尽量避免手动管理内存:
- 使用智能指针(如 std::unique_ptr、std::shared_ptr)自动管理生命周期
- 用 std::vector、std::string 等容器替代动态数组
- 若必须手动管理,确保 new/delete 成对出现,且作用域清晰
如果封装C风格接口,注意分配和释放接口风格统一。例如C++代码调用C库返回的 malloc 内存,应使用 free 释放。
基本上就这些。关键是匹配分配与释放方式,优先使用RAII机制,减少出错可能。










