new是C++运算符,支持构造函数调用并可能抛出异常;malloc是C函数,仅分配原始内存且返回NULL表示失败。

在C++中,new 和 malloc 都可以用来动态分配内存,但它们属于不同的内存管理机制,存在本质区别。理解这些差异有助于写出更安全、高效的代码。
1. 所属体系不同
new 是 C++ 的运算符,属于 C++ 语言级别的内存管理方式;而 malloc 是 C 标准库函数,定义在
这意味着:
- new 能够与构造函数、析构函数、重载等 C++ 特性无缝配合
- malloc 只负责分配原始内存块,不涉及对象语义
2. 内存分配失败时的行为不同
当内存不足导致分配失败时:
立即学习“C++免费学习笔记(深入)”;
- 使用 new:默认抛出 std::bad_alloc 异常,程序可捕获并处理
- 使用 malloc:返回 NULL 指针,需要手动检查返回值是否为 nullptr
例如:
int* p1 = new int; // 分配失败会抛异常
int* p2 = (int*)malloc(sizeof(int));
if (p2 == nullptr) { // 必须手动判断
// 处理分配失败
}3. 是否调用构造函数和析构函数
这是最关键的区别之一:
- new 在分配内存后,会自动调用对象的构造函数进行初始化
- malloc 仅分配指定大小的字节空间,不会调用任何构造函数
例如对于一个类类型:
class MyClass {
public:
MyClass() { cout << "构造函数被调用\n"; }
};
MyClass obj1 = new MyClass; // 构造函数会被调用
MyClass obj2 = (MyClass*)malloc(sizeof(MyClass)); // 不会调用构造函数
此时 obj2 指向的内存虽然足够存放对象,但并未初始化,直接使用成员函数可能导致未定义行为。
4. 内存释放方式不同
对应地,释放内存的方式也不同:
- new 配套使用 delete:delete 会先调用析构函数,再释放内存
- malloc 配套使用 free:只释放内存,不调用析构函数
错误混用会导致严重问题:
int* p = new int(10); free(p); // 错误!可能不会正确释放资源(尤其对类对象)int q = (int)malloc(sizeof(int)); *q = 20; delete q; // 错误!行为未定义
5. 类型安全性与语法简洁性
new 更加类型安全且语法简洁:
- new 自动计算所需内存大小,无需手动指定
- 返回指针自动匹配类型,不需要强制转换
- malloc 必须显式传入 sizeof,并且返回 void*,需手动转换
示例对比:
int* a = new int; // 简洁清晰 int* b = (int*)malloc(sizeof(int)); // 冗长,易出错
6. 支持数组操作的方式不同
C++ 提供了 new[] 和 delete[] 来管理数组:
- new[] 分配数组并逐个调用构造函数
- malloc 无法体现数组元素的构造逻辑
MyClass* arr1 = new MyClass[5]; // 正确:调用5次构造函数 MyClass* arr2 = (MyClass*)malloc(5 * sizeof(MyClass)); // 危险:未初始化对象
基本上就这些。在现代 C++ 中,推荐优先使用 new/delete(或更高级的智能指针),避免直接使用 malloc/free,除非在特定场景(如与 C 代码交互、实现底层内存池等)。两者不能混用,否则会导致资源泄漏或程序崩溃。











