C++中new和malloc有什么区别 构造与析构函数的影响

new会调用构造函数而malloc不会,1. new是操作符专为对象设计,自动调用构造函数,malloc仅分配原始内存;2. new/delete自动调用析构函数,malloc/free需手动调用;3. new返回具体类型指针无需转换,malloc返回void*需强转;4. new在内存不足时抛出异常,malloc返回NULL需手动检查。

C++中new和malloc有什么区别 构造与析构函数的影响

c++中,new和malloc都能用来动态分配内存,但它们之间存在本质区别,尤其是在涉及对象构造与析构时。简单来说:new会调用构造函数,而malloc不会

C++中new和malloc有什么区别 构造与析构函数的影响


1. 内存分配机制不同

new是C++的操作符,专为对象设计;它不仅分配内存,还会自动调用对象的构造函数。
malloc则是c语言标准库函数,只负责分配原始内存,不会执行任何构造逻辑。

C++中new和malloc有什么区别 构造与析构函数的影响

比如:

立即学习C++免费学习笔记(深入)”;

MyClass* obj1 = new MyClass();   // 分配内存 + 构造函数调用 MyClass* obj2 = (MyClass*)malloc(sizeof(MyClass));  // 仅分配内存,无构造函数调用

如果你用malloc来创建对象,后续要手动调用构造函数(可以通过定位new),否则对象状态不完整。

C++中new和malloc有什么区别 构造与析构函数的影响


2. 构造与析构函数的调用差异

使用new创建的对象,在生命周期结束时,通过delete释放内存时会自动调用析构函数。
而malloc分配的内存即使通过free释放,也不会调用析构函数。

这意味着:

  • 如果你管理的是类对象,忘记手动调用析构函数可能导致资源泄漏。
  • 使用new/delete能更安全地管理对象生命周期。

举个例子:

MyClass* obj = new MyClass(); delete obj;  // 正确调用析构函数  MyClass* raw = (MyClass*)malloc(sizeof(MyClass)); new(raw) MyClass();  // 手动调用构造函数 raw->~MyClass();     // 手动调用析构函数 free(raw);

3. 类型安全与返回值类型

  • new返回的是具体的类型指针,不需要强制转换。
  • malloc返回的是void*,必须手动强转为目标类型。

这点虽然看起来小,但在实际开发中会影响代码可读性和安全性。例如:

int* p1 = new int;    // 正确且无需转换 int* p2 = malloc(sizeof(int));  // 需要强转:int* p2 = (int*)malloc(sizeof(int));

4. 异常处理机制不同

  • new在内存不足时默认会抛出std::bad_alloc异常(除非使用nothrow版本)。
  • malloc则返回NULL,需要手动检查是否分配成功。

所以如果你希望程序在内存不足时有更灵活的处理方式,使用new(nothrow)或者检查malloc结果都是常见做法。


总的来说,如果你在C++中操作的是类对象,尤其是带有构造/析构逻辑的对象,应该优先使用new和delete。
只有在极少数情况下,比如需要直接操作内存块、或兼容C接口时,才考虑用malloc。

基本上就这些。

以上就是C++中new和malloc有什么

© 版权声明
THE END
喜欢就支持一下吧
点赞5 分享