深入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. angular-表格

    ng-repeat 指令可以完美的显示表格. <div ng-app="myApp" ng-controller="customersCtrl"> ...

  2. WinServer-IIS-IP及域的限制

    如果启用域名限制,那么会对服务器产生比较大的资源开销,慎重选择这个 来自为知笔记(Wiz)

  3. LeetCode104_MaximumDepthofBinaryTree Java题解

    题目: Given a binary tree, find its maximum depth. The maximum depth is the number of nodes along the ...

  4. fedora linux源代码下载

    yumdownloader --source kernel 如果是下载insight 就是 yumdownloader --source insight 下载到的是当前目录. 然后在用rpm2cpio ...

  5. Hibernate中session回话的get方法和load方法的区别

    1.报错方式不同: 前提:获取的数据不存在 get方法会报异常:空指针异常 load方法会报异常:对象为找到异常,给定值没有行存在. 2.load方法 这种方式总是会返回一个代理而不是真正得去查询数据 ...

  6. 关于Android的.so文件所须要知道的

    早期的Android系统差点儿仅仅支持ARMv5的CPU架构,你知道如今它支持多少种吗?7种. Android系统眼下支持以下七种不同的CPU架构:ARMv5.ARMv7 (从2010年起),x86 ...

  7. dotnet core test with NUnit

    https://github.com/nunit/dotnet-test-nunit if you are using Visual Studio. Your project.json in your ...

  8. GitHub客户端和Shell的基本操作和理解

    GitHub客户端和Shell指令的简单实用 客户端操作, web端操作, shell指令操作. 掌握了这三种操作,基本上就可以很好的运用gitHub了. 创建项目, 可以通过web端进行创建. 可以 ...

  9. 使用Networkx进行图的相关计算——黑产集团挖掘,我靠,可以做dns ddos慢速攻击检测啊

    # -*- coding: utf-8 -*- import networkx as nx import matplotlib.pyplot as plt iplist={} goodiplist={ ...

  10. KMP算法中求next数组的实质

    在串匹配模式中,KMP算法较蛮力法是高效的算法,我觉得其中最重要的一点就是求next数组: 看了很多资料才弄明白求next数组是怎么求的,我发现我的忘性真的比记性大很多,每次看到KMP算法求next数 ...