深入C++ new/delete,malloc/free解析

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

它们都可用于申请动态内存和释放内存

2.对于非内部数据类型的对象而言。光用maloc/free无法满足动态对象的要求。对象在创建的同一时候要自己主动运行构造函数。对象在消亡之前要自己主动运行析构函数。由malloc/free是库函数而不是

运算符,不在编译器控制权限之内,不可以把运行构造函数和析构函数的任务强加于malloc/free。

3.因此C++语言须要一个能完毕动态内存分配和初始化工作的运算符new,以一个能完毕清理与释放内存工作的运算符delete。注意new/delete不是库函数。

4.C++程序常常要调用C函数。而C程序仅仅能用malloc/free管理动态内存

5.new能够觉得是malloc加构造函数的运行。new出来的指针是直接带类型信息的。而malloc返回的都是void*指针。

new delete在实现上事实上调用了malloc,free函数

6.new建立的对象你能够把它当成一个普通的对象,用成员函数訪问,不要直接訪问它的地址空间;malloc分配的是一块内存区域,就用指针訪问好了,并且还能够在里面移动指针.

7.new建立的是一个对象。alloc分配的是一块内存.

***************************************

同样点:都可用于申请动态内存和释放内存

***************************************

不同点:

(1)操作对象有所不同。

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

对于非内部数据类的对象而言,光用maloc/free 无法满足动态对象的要求。对象在创建的同一时候要自己主动运行构造函数。

对象消亡之前要自己主动运行析构函数。因为malloc/free 是库函数而不是运算符,不在编译器控制权限之内,不可以把运行构造函数和析构函数的任务强加malloc/free。

(2)在使用方法上也有所不同。

函数malloc 的原型例如以下:

void * malloc(size_t size);

用malloc 申请一块长度为length 的整数类型的内存,程序例如以下:

int*p = (int *) malloc(sizeof(int) * length);

我们应当把注意力集中在两个要素上:“类型转换”和“sizeof”。

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

malloc函数本身并不识别要申请的内存是什么类型。它仅仅关心内存的总字节数。

函数free 的原型例如以下:

void free( void * memblock );

为什么free 函数不象malloc 函数那样复杂呢?这是由于指针p 的类型以及它所指的内存的容量事先都是知道的,语句free(p)能正确地释放内存。

假设p 是NULL 指针,那么free

对p
不管操作多少次都不会出问题。假设p 不是NULL 指针。那么free 对p连续操作两次就会导致程序执行错误。

new/delete的使用要点

运算符new 使用起来要比函数malloc 简单得多。比如:

int*p1 = (int *)malloc(sizeof(int) * length);

int*p2 = new int[length];

这是由于new 内置了sizeof、类型转换和类型安全检查功能。

对于非内部数据类型的对象而言,new 在创建动态对象的同一时候完毕了初始化工作。

假设对象有多个构造函数。那么new 的语句

也能够有多种形式。

假设用new 创建对象数组,那么仅仅能使用对象的无參数构造函数。

比如

Obj*objects = new Obj[100]; // 创建100 个动态对象

不能写成

Obj*objects = new Obj[100](1);// 创建100 个动态对象的同一时候赋初值1

在用delete 释放对象数组时,留意不要丢了符号‘[]’。

比如

delete[]objects; // 正确的使用方法

deleteobjects; // 错误的使用方法

后者相当于delete objects[0],漏掉了另外99 个对象。

***************************************

1  new自己主动计算须要分配的空间。而malloc须要手工计算字节数

2  new是类型安全的。而malloc不是,比方:

int* p = new float[2]; // 编译时指出错误

int* p = malloc(2*sizeof(float)); // 编译时无法指出错误

new operator 由两步构成。各自是 operator new 和 construct

3  operator new相应于malloc,但operator new能够重载,能够自己定义内存分配策略,甚至不做内存分配,甚至分配到非内存设备上。而malloc无能为力

4  new将调用constructor,而malloc不能。delete将调用destructor,而free不能。

5  malloc/free要库文件支持,new/delete则不要。

深入C++ new/delete,malloc/free解析的更多相关文章

  1. C++ new delete malloc free

    title: C++ new delete malloc free date: 2020-03-10 categories: c++ tags: 语法 C++的new delete malloc fr ...

  2. new和delete malloc和free

    程序中动态分配的对象存放在自由存储区(free store)或堆(heap). C语言程序使用一对标准库函数malloc和free在自由存储区中分配存储空间,而C++语言则使用new和delete表达 ...

  3. new,delete,malloc,free

    malloc/free是C语言中的内存申请和释放函数,利用它们可方便地管理内存.而在C++中我们又有了新的工具:new/delete.new/delete在管理内存的同时会调用类的构造函数和析构函数, ...

  4. 内存分配方式,堆区,栈区,new/delete/malloc/free

    1.内存分配方式 内存分配方式有三种: [1]从静态存储区域分配.内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在.例如全局变量,static变量. [2]在栈上创建.在执行函数时 ...

  5. C++之new/delete/malloc/free详解

    主要内容: 1.  C语言中的函数malloc和free 2.  C++中的运算符new和delete 3.  new/delete与malloc/free之间的联系和区别 4.  C/C++程序的内 ...

  6. C++/C语言的标准库函数与运算符的区别new/delete malloc/free

    malloc与free是C++/C语言的标准库函数,new/delete是C++的运算符.它们都可用于申请动态内存和释放内存.下面来看他们的区别. 一.操作对象有所不同 malloc与free是C++ ...

  7. 内存分配(new/delete,malloc/free,allocator,内存池)

    以下来源http://www.cnblogs.com/JCSU/articles/1051826.html 程序员们经常编写内存管理程序,往往提心吊胆.如果不想触雷,唯一的解决办法就是发现所有潜伏的地 ...

  8. C/C++ 内存分配方式,堆区,栈区,new/delete/malloc/free

    内存分配方式 内存分配方式有三种: [1] 从静态存储区域分配.内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在.例如全局变量, static 变量. [2] 在栈上创建.在执行函 ...

  9. 动态内存的分配(new delete malloc free)

    new和malloc的区别是什么?-new关键字是C++的一部分,在所有的C++编译器中都被支持-malloc是由C库提供的函数,在某些系统开发中是不能调用的-new以具体类型为单位进行内存分配-ma ...

随机推荐

  1. C语言 将十六进制字符串转为十六进制数 (二进制、十进制都适用)

    主要利用 long int strtol(const char *nptr,char **endptr,int base); 函数 函数说明: 参数base范围从2至36,或0.参数base代表采用的 ...

  2. mysql数据实时同步到Elasticsearch

    业务需要把mysql的数据实时同步到ES,实现低延迟的检索到ES中的数据或者进行其它数据分析处理.本文给出以同步mysql binlog的方式实时同步数据到ES的思路, 实践并验证该方式的可行性,以供 ...

  3. Ruby print

    Ruby print

  4. POJ 题目3237 Tree(Link Cut Tree边权变相反数,求两点最大值)

    Tree Time Limit: 5000MS   Memory Limit: 131072K Total Submissions: 6131   Accepted: 1682 Description ...

  5. kentico version history and upgrade

    Version history Kentico 10: November 30, 2016 Kentico 9: November 24, 2015 Kentico 8.2: January 6, 2 ...

  6. poj--3984--迷宫问题(bfs+路径记录)

    迷宫问题 Time Limit: 1000MS   Memory Limit: 65536KB   64bit IO Format: %I64d & %I64u Submit Status D ...

  7. Redis-2-对于key的通用操作

    Redis-2-对于key的通用操作 标签(空格分隔): redis del key key1 key2 作用: 删除1个或多个键 返回值: 不存在的key忽略掉,返回真正删除的key的数量 rena ...

  8. 如何让一台IIS服务器实现多个网站https访问

    找到注册表项:HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\HTTP\Parameters\SslSniBindingInfo,将注册表值改 ...

  9. C# 导出excel的压缩包到浏览器页面

    需求背景:TCX_1710项目产品质量导出功能,客户希望每个总成导出到一个Excel表中 实现分析:客户选择时间段,点击导出按钮,默认导出开始时间当天的数据,每个总成一个Excel,将各个Excel打 ...

  10. Codeforces 930A. Peculiar apple-tree (dfs)

    题目: 代码: #include <bits\stdc++.h> using namespace std; ]; //b[i]表示距离1号花絮i步的花絮的个数 map <int, l ...