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

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

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

比如:
立即学习“C++免费学习笔记(深入)”;
MyClass* obj1 = new MyClass(); // 分配内存 + 构造函数调用MyClass* obj2 = (MyClass*)malloc(sizeof(MyClass)); // 仅分配内存,无构造函数调用
如果你用malloc来创建对象,后续要手动调用构造函数(可以通过定位new),否则对象状态不完整。

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有什么区别 构造与析构函数的影响的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1464000.html
微信扫一扫
支付宝扫一扫