1.new调用构造函数,malloc++不调用;2.delete调用析构函数,free不调用;3.new失败抛异常,malloc返回null。在c++中,new不仅分配内存还会自动调用构造函数,而malloc仅分配原始内存块,不会初始化对象;delete会在释放内存前调用析构函数,free则直接归还内存而不处理析构逻辑;此外,new在内存不足时默认抛出bad_alloc异常,malloc失败时返回空指针;建议优先使用new/delete管理c++对象,若使用malloc需手动调用构造函数和析构函数以避免资源泄漏或未定义行为。

在C++中,new和malloc虽然都能用来动态分配内存,但它们之间有几个关键区别,尤其是构造函数和析构函数的调用问题,这是很多人容易忽略但也最容易出错的地方。

new会调用构造函数,而malloc不会
当你使用new来创建一个对象时,比如:

MyClass* obj = new MyClass();
它不仅分配了内存,还会自动调用该类的构造函数。如果你用的是数组形式:
立即学习“C++免费学习笔记(深入)”;
MyClass* arr = new MyClass[10];
那每个元素都会调用自己的构造函数。

而malloc只是简单地分配一块原始内存,例如:
MyClass* obj = (MyClass*)malloc(sizeof(MyClass));
这时候不会调用任何构造函数,你拿到的只是一个未初始化的对象内存块。如果这个类内部有复杂的初始化逻辑(比如动态分配资源、引用计数等),直接访问这个对象就会导致未定义行为。
delete会调用析构函数,free则完全不处理
和new配对的是delete,它会在释放内存前先调用析构函数,确保对象正确清理资源:
delete obj;
如果是数组,则应该用:
delete[] arr;
这样每个元素的析构函数都会被调用。
而free()只是把内存还给系统,不做任何析构操作:
free(obj);
这会导致如果对象里有需要释放的资源(比如文件句柄、堆内存),这些资源就“漏”掉了,造成资源泄漏或程序异常。
内存分配失败时的行为不同
new默认情况下在内存不足时会抛出std::bad_alloc异常。而malloc失败时只会返回NULL指针。
当然,你可以使用new (std::nothrow)来改变这种行为,让它返回空指针而不是抛异常:
MyClass* obj = new (std::nothrow) MyClass();if (!obj) { // 处理内存分配失败的情况}
使用建议:优先用new/delete管理C++对象
除非你在写底层代码、性能敏感区域或者与C库交互,否则:
对于C++类对象,尽量使用new和delete如果用了malloc,记得手动调用构造函数(可以用定位new)同样,释放前也要手动调用析构函数再用free
举个例子,配合定位new使用malloc:
void* mem = malloc(sizeof(MyClass));MyClass* obj = new(mem) MyClass(); // 手动调用构造函数// 使用完成后obj->~MyClass(); // 手动调用析构函数free(mem);
基本上就这些。理解这两者的差异,特别是在构造/析构上的行为区别,能避免很多资源泄漏和未定义行为的问题。
以上就是C++中new和malloc有什么区别 构造/析构函数调用的关键差异的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1467041.html
微信扫一扫
支付宝扫一扫