malloc/free和new/delete

一. 执行内容:

malloc / free:

malloc 函数的参数接收所需分配的内存字节数,如果内存满足请求量,将返回指向被分配内存起始地址的指针;

free 释放指针所指向的内存,其中指针必须指向所释放内存空间的首地址;

new / delete:

new 分为两步:1).通过operator new 分配内存      2).为被分配的内存调用一个或多个构造函数构建对象;

delete 也分两步: 1).为将被释放的内存调用一个或多个析构函数      2).通过operator delete 释放内存;

二. 本质区别:

1.malloc/free是C/C++语言的标准库函数,new/delete是C++的运算符;

2.对于用户自定义的对象而言,用maloc/free无法满足动态管理对象的要求。对象在创建的同时要自动执行构造函数,对象在消亡之前要自动执行析构函数。由于malloc/free是库函数而不是运算符,不在编译器控制权限之内,不能够把执行构造函数和析构函数的任务强加于malloc/free。因此C++需要一个能对对象完成动态内存分配和初始化工作的运算符new,以及一个能对对象完成清理与释放内存工作的运算符delete---简而言之 new/delete能进行对对象进行构造和析构函数的调用进而对内存进行更加详细的工作,而malloc/free不能。

三. 两者联系:

既然new/delete的功能完全覆盖了malloc/free,为什么C++还保留malloc/free呢?因为C++程序经常要调用C函数,而C程序只能用malloc/free管理动态内存。如果用free释放“new创建的动态对象”,那么该对象因无法执行析构函数而可能导致程序出错。如果用delete释放“malloc申请的动态内存”,理论上讲程序不会出错,但是该程序的可读性很差。所以new/delete,malloc/free必须配对使用。

四. 使用要点:

int *p1 = (int *)malloc(sizeof(int) * length);
free(p1);
int *p2 = new int[length];
delete [] p2;

1.malloc 函数本身并不识别要申请的内存是什么类型,它只关心内存的总字节数;

2.malloc 返回值的类型是void *,所以在调用malloc 时要显式地进行类型转换,将void * 转换成所需要的指针类型;

3.运算符new 使用起来要比函数malloc 要更简单在于能动态分配内存,new 内置了sizeof、类型转换和类型安全检查功能;对于非内部数据类型的对象而言,new 在创建动态对象的同时完成了初始化工作;如果对象有多个构造函数,那么new 的语句也可以有多种形式。

4.如果用new 创建对象数组,那么只能使用对象的无参数构造函数;

Obj *objects = new Obj[100];            // RIGHT   

Obj *objects = new Obj[100](1);       // WRONG

时间: 2024-08-02 21:43:39

malloc/free和new/delete的相关文章

比较malloc/free和new/delete

比较malloc/free和new/delete ??涉及到内存分配时,经常用到malloc与free.malloc与free是C++/C的标准库函数,new/delete是C++的运算符.它们都可用于申请动态内存和释放内存. ??对于非内部数据类型的对象而言,光用 malloc/free 无法满足动态对象的要求.对象在创建的同时要自动执行构造函数,对象在消亡之前要自动执行析构函数.由于 malloc/free是库函数而不是运算符,不在编译器控制权限之内,不能够把执行构造函数和析构函数的任务强加

C++拾遗--malloc free与new delete的同与不同

C++拾遗--malloc free与new delete的同与不同 前言 在C中我们常使用malloc和free来动态分配与释放内存,在C++中对应的是new和delete.这里我们来探讨下他们的同与不同. 正文 1.内置类型 对相同的代码进行调试,查看内存 #include <iostream> using namespace std; int main() { int *p = (int*)malloc(sizeof(int) * 10); cout << p <<

malloc/free与new/delete的区别

相同点:都可用于申请动态内存和释放内存 不同点:(1)操作对象有所不同.malloc与free是C++/C 语言的标准库函数,new/delete 是C++的运算符.对于非内部数据类的对象而言,光用maloc/free 无法满足动态对象的要求.对象在创建的同时要自动执行构造函数, 对象消亡之前要自动执行析构函数.由于malloc/free 是库函数而不是运算符,不在编译器控制权限之内,不能够把执行构造函数和析构函数的任务强加malloc/free. (2)用法上也有所不同.函数malloc 的原

malloc/free和new/delete的区别汇总

一.基本概念 malloc/free 1.函数原型及说明: void* malloc(long NumBytes):该函数分配了NumBytes个字节,并返回了指向这块内存的指针.如果分配失败,则返回一个空指针(NULL). void free(void* FirstByte):该函数是将之前用malloc分配的空间还给程序或者操作系统,也就是释放了这块内存,让它重新得到自由. 2.内存操作: malloc函数的参数是接受需要分配的内存字节数,如果内存能够满足请求量,那么将会返回,指向被分配的内

malloc free 和new delete区别

从网上看的学习之 1. malloc与free是C++/C语言的标准库函数,new/delete是C++的运算符,与"+"."-"."*"."/"有一样的地位. 2. new/delete是可以重载的,而重载之后,就成为了函数. 3. malloc在申请内存的时候,必须要提供申请的长度,而且返回的指针是void*型,必须要强转成需要的类型. 4. 当new/delete在类中被重载的时候,可以自定义申请过程,比如记录所申请内存

malloc/free、new/delete 区别

1. Malloc:malloc/free是C++和C的标准库函数,可用于申请动态内存和释放内存.对于非内部数据类型的对象而言,光用 malloc/free无法满足动态对象的要求.对象在创建的同时要自动执行构造函数,对象在消亡之前要自动执行析构函数.由于malloc/free是 库函数而不是运算符,不在编译器控制权限之内,不能够把执行构造函数和析构函数的任务强加于malloc/free. 2. New:new/delete是C++的运算符.可用于申请动态内存和释放内存.C++语言需要一个能完成动

百度笔试题:malloc/free与new/delete的区别(转)

百度笔试题:malloc/free与new/delete的区别 相同点:都可以申请动态内存和释放内存. 不同点: (1) 操作对象有所不同: malloc和free是C/C++的标准库函数,new和delete是C++的运算符.对于非内部数据类的对象而言,光用malloc/free 无法满足动态对象的要求.对象在创建时要自动执行构造函数,对象消亡之前要自动执行析构函数,malloc和free是库函数而不是运算符,不在编译器的控制权限之内,不能够把执行构造函数和析构函数的任务强加给malloc/f

malloc/free 与 new/delete的区别和联系

一.基本概念  malloc/free: 1.函数原型及说明: void *malloc(long NumBytes):该函数分配了NumBytes个字节,并返回了指向这块内存的指针.如果分配失败,则返回一个空指针(NULL). void free(void *FirstByte): 该函数是将之前用malloc分配的空间还给程序或者是操作系统,也就是释放了这块内存,让它重新得到自由. 2.内存操作: malloc函数的参数是接受需要分配的内存字节数,如果内存能够满足请求量,那么将会返回:指向被

malloc/free和new/delete的异同

一.基本概念 malloc/free: 1.函数原型及说明: void *malloc(long NumBytes):该函数分配了NumBytes个字节,并返回了指向这块内存的指针.如果分配失败,则返回一个空指针(NULL). void free(void *FirstByte): 该函数是将之前用malloc分配的空间还给程序或者是操作系统,也就是释放了这块内存,让它重新得到自由. 2.内存操作: malloc函数的参数是接受需要分配的内存字节数,如果内存能够满足请求量,那么将会返回:指向被分

malloc/free 和 new/delete

一.Malloc/free 1.Malloc的原型:(#include <malloc.h>) Void * malloc(size_t size);   //  Void * malloc(unsigned int num_bytes); 如果分配失败,则返回NULL,否则返回申请内存的首地址.malloc本身并不识别要申请内存的类型(返回类型为void *),只关心内存的字节数,因此必须显式的进行类型转化. 2.Free的原型: Void free(void *memblock); 如果f