C++ malloc与new区别_C++内存分配方式对比

malloc是C库函数,仅分配内存不调用构造函数,失败返回NULL;new是C++关键字,分配内存并调用构造函数,失败抛出异常或返回nullptr,且可重载;应避免混用malloc/new及free/delete。

mallocnew 都用于动态分配内存,但它们在机制、使用方式和功能上有显著区别。理解这些差异对编写高效、安全的C++程序至关重要。

1. 所属体系不同

malloc 是C语言的库函数,定义在 stdlib.h(或C++中的 cstdlib)中,属于C运行时库。它只负责分配原始内存块,不涉及对象构造。

new 是C++的关键字,由编译器支持,是C++语言的一部分。它不仅分配内存,还会自动调用对象的构造函数。

2. 内存分配与初始化行为

使用 malloc 分配内存后,内存是未初始化的,需要手动初始化。对于类类型,不会调用构造函数。

int* p1 = (int*)malloc(sizeof(int)); // 分配4字节,值未定义

new 会分配内存并自动调用构造函数,确保对象正确初始化。

int* p2 = new int(); // 分配并初始化为0MyClass* obj = new MyClass(); // 调用构造函数

3. 内存分配失败的处理方式

malloc 在分配失败时返回 NULL,需要显式检查指针是否为空。

int* p = (int*)malloc(sizeof(int) * 100);
if (p == NULL) { /* 处理错误 */ }

new 默认在失败时抛出 std::bad_alloc 异常。也可使用 nothrow 版本返回空指针:

int* p = new(std::nothrow) int[100];
if (p == nullptr) { /* 处理失败 */ }

4. 内存释放方式必须匹配

必须用 free 释放 malloc 分配的内存,用 deletedelete[] 释放 new 分配的内存。混用会导致未定义行为。

int* p1 = (int*)malloc(10 * sizeof(int));
free(p1); // 正确

int* p2 = new int[10];
delete[] p2; // 正确

如果对使用 new 创建的对象使用 free,构造函数被调用了但析构函数不会被 free 调用,可能导致资源泄漏。

5. 支持重载与自定义行为

new 可以被重载,允许类自定义内存分配策略。例如实现对象池或调试内存分配。

malloc 是标准C函数,无法重载,行为固定。

基本上就这些。malloc更底层,适合C风格编程;new更符合C++面向对象特性,能自动管理对象生命周期。现代C++推荐优先使用 new(或更推荐智能指针),避免直接使用 malloc。两者不要混用,防止内存问题。