new是c++操作符,分配内存并调用构造函数,malloc是C函数,仅分配原始内存不调用构造函数;2. new根据类型自动计算大小且无需类型转换,malloc需手动计算并强制转换;3. delete会先调用析构函数再释放内存,free仅释放内存。

在C++中,new 和 malloc 都可以用来动态分配内存,但它们的机制和用途有本质区别。理解这些差异对于掌握C++内存管理至关重要。
内存分配方式不同
malloc 是c语言中的函数,位于 cstdlib 头文件中,仅负责从堆上分配指定大小的原始内存块,不调用构造函数。它返回的是 void* 指针,需要手动进行类型转换。
new 是C++的操作符,不仅分配内存,还会自动调用对象的构造函数。它根据对象类型确定所需内存大小,无需显式计算字节数,也不需要强制类型转换。
例如:
立即学习“C++免费学习笔记(深入)”;
// 使用 malloc int* p1 = (int*)malloc(sizeof(int)); // 需要手动初始化 *p1 = 10; <p>// 使用 new int* p2 = new int(10); // 自动调用构造并初始化
对象构造与析构行为差异
这是两者最核心的区别。使用 malloc 分配的内存只是“空的字节”,不会触发类对象的构造函数。如果是一个类类型,成员变量将处于未初始化状态。
而 new 在分配内存后,会立即调用相应构造函数,完成对象的初始化。同样地,delete 会先调用析构函数再释放内存,而 free 只释放内存,不会调用析构函数。
举例说明:
class MyClass { public: MyClass() { cout << "构造函数被调用n"; } ~MyClass() { cout << "析构函数被调用n"; } }; <p>// 错误做法:malloc 不会调用构造函数 MyClass<em> obj1 = (MyClass</em>)malloc(sizeof(MyClass)); // 无构造调用</p><p>// 正确做法:new 会调用构造函数 MyClass* obj2 = new MyClass(); // 构造函数执行
内存释放方式必须匹配
使用 malloc 分配的内存必须用 free 释放,而 new 出来的对象必须用 delete 释放。混用可能导致未定义行为,比如资源泄漏或程序崩溃。
- malloc + free:C风格内存管理
- new + delete:C++对象生命周期管理
尤其注意数组情况:
- new[] 配合 delete[]
- malloc 数组需用 free,不能用 delete
异常处理机制不同
当内存不足时,malloc 返回 NULL,需要手动检查指针是否为空。
new 默认抛出 std::bad_alloc 异常,可以通过设置nothrow版本使其返回nullptr:
int* p1 = new (std::nothrow) int[1000]; // 分配失败返回 nullptr if (!p1) { // 处理分配失败 }
基本上就这些。new 更适合C++对象管理,因为它兼顾内存分配与构造逻辑;malloc 更偏向底层内存操作,适用于非对象数据或与C兼容的场景。正确选择取决于你是否需要构造/析构语义。


