delete与new配对,free与malloc配对,不可混用;new/delete自动调用构造/析构函数,free不处理析构;C++推荐使用new/delete及智能指针避免手动管理。
在C++中,内存管理是程序开发的重要部分,正确使用内存释放操作符能避免内存泄漏和程序崩溃。关于 delete 和 free 的使用,必须遵循明确的规范,因为它们分别对应不同的内存分配方式和语言机制。
1. delete 与 new 配对使用
在C++中,使用 new 动态分配的对象,必须用 delete 释放。delete 不仅释放内存,还会调用对象的析构函数,确保资源正确清理。
基本规则:
- 单个对象用 new 分配,用 delete 释放
- 数组用 new[] 分配,用 delete[] 释放
错误示例:
int* p = new int[10];
delete p; // 错误:应使用 delete[]
正确写法:
立即学习“C++免费学习笔记(深入)”;
int* p = new int[10];
delete[] p; // 正确
2. free 与 malloc/calloc/realloc 配对使用
free 是c语言的内存释放函数,用于释放由 malloc、calloc 或 realloc 分配的内存。它不会调用C++对象的析构函数,因此不能用于 new 创建的对象。
适用场景:
- 纯C风格内存分配
- 与C库交互时分配的内存
正确示例:
int* p = (int*)malloc(10 * sizeof(int));
free(p); // 正确
3. 不要混用 new/malloc 与 delete/free
new 和 malloc 属于不同的内存管理机制,混用会导致未定义行为。
- new 分配的内存不能用 free 释放
- malloc 分配的内存不能用 delete 释放
危险操作:
int* p = new int(5);
free(p); // 错误:未调用析构函数,行为未定义
void* p = malloc(sizeof(MyClass));
MyClass* obj = new(p) MyClass();
delete obj; // 可能出错:内存不是 new 分配的
4. 建议优先使用C++风格内存管理
在C++项目中,推荐使用 new/delete 而非 malloc/free,因为:
更进一步,现代C++推荐使用智能指针(如 std::unique_ptr、std::shared_ptr)和容器(如 std::vector),避免手动管理内存。
基本上就这些。关键是匹配分配与释放方式,别交叉使用,就能避免大部分内存问题。
评论(已关闭)
评论已关闭