有了 malloc/free 为什么还要 new/delete ?

本文介绍了C++中用于内存管理的两种不同方式:malloc/free与new/delete。malloc/free属于C/C++标准库函数,用于基本的内存分配与释放;而new/delete作为C++特有的运算符,不仅能够分配内存,还能调用构造和析构函数完成对象的初始化与清理工作。

mallocfreeC++/C语言的标准库函数,new/deleteC++的运算符。它们都可用于申请动态内存和释放内存。对于非

内部数据类型的对象而言,光用 malloc/free无法满足动态对象的要求。对象在创建的同时要自动执行构造函数,对象在

消亡之前要自动执行析构函数。由于malloc/free 是库函数而不是运算符,不在编译器控制权限之内,不能够把执行构造

函数和析构函数的任务强加于malloc/free。因此C++语言需要一个能完成动态内存分配和初始化工作的运算符new,以及

一个能完成清理与释放内存工作的运算符delete。注意new/delete不是库函数。

`malloc`/`free` `new`/`delete` 都是用于动态内存管理的工具,但它们在C++中有不同的用途行为。 1. **类型安全**: - `malloc` 只分配内存,但不会调用构造函数。因此,它不适用于需要构造函数初始化的对象。 - `new` 不仅分配内存,还会调用对象的构造函数,确保对象被正确初始化。 ```cpp class MyClass { public: MyClass() { std::cout << "Constructor called\n"; } ~MyClass() { std::cout << "Destructor called\n"; } }; int main() { // 使用 malloc 分配内存,但不会调用构造函数 MyClass *obj1 = (MyClass *)malloc(sizeof(MyClass)); free(obj1); // 使用 new 分配内存并调用构造函数 MyClass *obj2 = new MyClass(); delete obj2; return 0; } ``` 2. **内存释放**: - `free` 只释放内存,不会调用析构函数。 - `delete` 在释放内存之前会先调用对象的析构函数,确保资源被正确清理。 3. **语法差异**: - `malloc` `free` 是C语言中的函数,返回的是 `void*` 类型的指针,需要显式类型转换。 - `new` `delete` 是C++的操作符,直接返回指定类型的指针,不需要显式类型转换。 ### 解释: - **类型安全**:`new` `delete` 提供了更强的类型安全性,因为它们会自动调用构造函数析构函数,这对于管理复杂对象非常重要。 - **内存管理**:`malloc` `free` 不了解C++对象的生命周期,而 `new` `delete` 则能够正确处理对象的创建销毁。 - **语法简洁性**:`new` `delete` 的语法更加简洁,减少了类型转换的错误。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值