new是C++运算符,具备类型安全、自动计算大小、调用构造函数、抛出异常处理失败,并支持重载和数组分配;malloc是C函数,需手动指定字节、返回void*、不调用构造函数、返回NULL表示失败,且仅通过free释放内存,不兼容析构。2. C++中应优先使用new/delete或智能指针以确保对象正确初始化与销毁,遵循RAII原则,malloc/free适用于C或底层场景。

在C++中,new 和 malloc 都可以用来动态分配内存,但它们在机制、使用方式和功能上存在本质区别。理解这些差异对于写出安全、高效的C++代码非常重要。
1. 所属语言与类型安全
new 是C++的运算符,而 malloc 是C语言的标准库函数(定义在
- new 在分配内存时会自动计算所需大小,不需要手动指定字节数。
- malloc 必须显式传入字节数(通过 sizeof 计算),容易出错。
- new 返回的是具体类型的指针(如 int*),类型安全;malloc 返回 void*,需要强制转换才能使用,容易引发类型错误。
2. 构造函数与对象初始化
这是最关键的区别之一。
- 使用 new 分配对象时,会自动调用该对象的构造函数。
- malloc 只分配原始内存块,不会调用构造函数,对象处于未初始化状态。
例如:
立即学习“C++免费学习笔记(深入)”;
MyClass* obj1 = new MyClass(); // 调用构造函数MyClass* obj2 = (MyClass*)malloc(sizeof(MyClass)); // 不调用构造函数,obj2 没有被正确初始化
3. 内存分配失败的处理方式
- new 在内存不足时默认抛出 std::bad_alloc 异常,程序可以捕获并处理。
- malloc 在失败时返回 NULL,必须手动检查返回值。
这意味着使用 malloc 时更容易因忘记检查空指针而导致崩溃。
4. 内存释放方式不同
- new 配套使用 delete,delete 会先调用析构函数,再释放内存。
- malloc 配套使用 free(),只释放内存,不调用析构函数。
混用会导致未定义行为:
int* p = new int(5);free(p); // 错误!应使用 delete
int* q = (int*)malloc(sizeof(int));
delete q; // 错误!应使用 free()
5. 支持重载与自定义行为
- new 可以被类重载,实现自定义内存管理逻辑。
- malloc 是全局函数,无法重载。
6. 数组分配支持
- new[] 用于分配数组,并对每个元素调用构造函数。
- malloc 需要手动计算总大小,且不调用构造函数。
- 对应地,new[] 必须用 delete[] 释放,否则可能导致资源泄漏或崩溃。
基本上就这些。虽然两者都能分配内存,但在C++中推荐优先使用 new/delete(或更现代的智能指针),因为它能保证对象正确构造和析构,符合RAII原则。malloc/free 更适合纯C场景或底层内存操作。











