今天问同学的面试情况,他说出了这个问题,但是当时只能答出:free有三步,计算所需要分配的内存空间大小,调用构造函数,返回内存的地址;malloc 只有两步,分配内存,返回内存地址。所以最大的区别就是new会调用构造函数,malloc不调用构造函数。。。这个答案面试官应该不会满意吧。。。
追本溯源
转载自这篇文章,总结得非常到位,方便自己再看。。。
最大区别: new在申请空间的时候会调用构造函数,malloc不会调用。
属性上: new/delete是C++关键字需要编译器支持,maollc是库函数,需要添加头文件。
申请失败返回: new在申请空间失败后返回的是错误码bad_alloc,malloc在申请空间失败后会返回NULL。
参数: new在申请内存分配时不需要指定内存块大小,编译器会更具类型计算出大小,malloc需要显示的指定所需内存的大小
成功返回类型: new操作符申请内存成功时,返回的是对象类型的指针,类型严格与对象匹配,无需进行类型转换,因此new是类型安全性操作符。malloc申请内存成功则返回void*,需要强制类型转换为我们所需的类型
自定义类型: new会先调operator new函数,申请足够的内存(底层也是malloc实现),然后调用类的构造函数,初始化成员变量,最后返回自定义类型指针。delete先调用析构函数,然后调用operator delete函数来释放内存(底层是通过free实现)。malloc/free是库函数,只能动态的申请和释放内存,无法强制要求其做自定义类型对象构造和析构函数
重载: C++允许重载new/delete操作符,特别的,布局new的就不需要为对象分配内存,而是指定了一个地址作为内存起始区域,new在这段内存上为对象调用构造函数完成初始化工作,并返回地址。malloc不允许重载。
从上面可以知道,delete和free的区别,也知道一二了。那么delete和free的共同点呢?
它们都是只把指针所指向的内存释放掉了,指针变量本身还是存在的,只是都指向NULL。在free和delete之后,都需要把指向清理内存的指针置为空(程序员主动置为NULL),否则指针指向的内存空间虽然释放了,但是指针p的值还是记录的那块地址**,该地址对应的内存是垃圾,p就成了“野指针”**。
注意!!!野指针不是NULL指针!!!