new和delete malloc和free
程序中动态分配的对象存放在自由存储区(free store)或堆(heap)。
C语言程序使用一对标准库函数malloc和free在自由存储区中分配存储空间,而C++语言则使用new和delete表达式实现相同的功能。
new分配失败会抛出异常,分配成功则返回分配空间的起始地址;
alloc分配失败返回空指针NULL,分配成功则返回分配空间的起始地址;
malloc与new的区别:
(1)new返回指定类型的指针,并且可以自动计算所需要的内存大小。malloc必须我们计算字节数,并且在返回后强行转换为实际类型的指针。
例:int *pia = new int[10]; //返回类型为 int*(new表达式返回指向新分配数组的第一个元素的指针),分配大小为sizeof(int)*10.
int *pia = (int *)malloc(sizeof(int)*10) //分配10个int型的存储单元,并将首地址存放到pia中.
(2)关于初始化:malloc只管进行分配的内存,没有对其进行初始化,其内存的值是随机值。
new可以对其进行值初始化: int *pia = new int[10](); //圆括号要求对数组做值初始化,这里的数组元素全部初始化为0(全部初始化为元素类型的默认值)
TreeNode *root = new TreeNode(3); //调用结构体TreeNode里的构造函数,进行值初始化。
(3)调用malloc时一定要进行返回值判断:
malloc函数的实质体现在,它有一个将可用的内存块连接为一个长长的列表的所谓空闲链表。调用malloc函数时,它沿连接表寻找一个大到足以满足用户请求所需要的内存块。然后,将该内存块一分为二(一块的大小与用户请求的大小相等,另一块的大小就是剩下的字节)。接下来,将分配给用户的那块内存传给用户,并将剩下的那块(如果有的话)返回到连接表上。调用free函数时,它将用户释放的内存块连接到空闲链上。到最后,空闲链会被切成很多的小内存片段,如果这时用户申请一个大的内存片段,那么空闲链上可能没有可以满足用户要求的片段了。于是,malloc函数请求延时,并开始在空闲链上翻箱倒柜地检查各内存片段,对它们进行整理,将相邻的小空闲块合并成较大的内存块。如果无法获得符合要求的内存块,malloc函数会返回NULL指针,因此在调用malloc动态申请内存块时,一定要进行返回值的判断。
注意:
new和delete malloc和free的更多相关文章
- 深入C++ new/delete,malloc/free解析
		
深入C++ new/delete,malloc/free解析 1.malloc与free是C++/C语言的标准库函数.new/delete是C++的运算符. 它们都可用于申请动态内存和释放内存 2.对 ...
 - C++ new delete malloc free
		
title: C++ new delete malloc free date: 2020-03-10 categories: c++ tags: 语法 C++的new delete malloc fr ...
 - new,delete,malloc,free
		
malloc/free是C语言中的内存申请和释放函数,利用它们可方便地管理内存.而在C++中我们又有了新的工具:new/delete.new/delete在管理内存的同时会调用类的构造函数和析构函数, ...
 - 内存分配方式,堆区,栈区,new/delete/malloc/free
		
1.内存分配方式 内存分配方式有三种: [1]从静态存储区域分配.内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在.例如全局变量,static变量. [2]在栈上创建.在执行函数时 ...
 - C++之new/delete/malloc/free详解
		
主要内容: 1. C语言中的函数malloc和free 2. C++中的运算符new和delete 3. new/delete与malloc/free之间的联系和区别 4. C/C++程序的内 ...
 - C++/C语言的标准库函数与运算符的区别new/delete malloc/free
		
malloc与free是C++/C语言的标准库函数,new/delete是C++的运算符.它们都可用于申请动态内存和释放内存.下面来看他们的区别. 一.操作对象有所不同 malloc与free是C++ ...
 - 内存分配(new/delete,malloc/free,allocator,内存池)
		
以下来源http://www.cnblogs.com/JCSU/articles/1051826.html 程序员们经常编写内存管理程序,往往提心吊胆.如果不想触雷,唯一的解决办法就是发现所有潜伏的地 ...
 - C/C++ 内存分配方式,堆区,栈区,new/delete/malloc/free
		
内存分配方式 内存分配方式有三种: [1] 从静态存储区域分配.内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在.例如全局变量, static 变量. [2] 在栈上创建.在执行函 ...
 - 动态内存的分配(new delete malloc free)
		
new和malloc的区别是什么?-new关键字是C++的一部分,在所有的C++编译器中都被支持-malloc是由C库提供的函数,在某些系统开发中是不能调用的-new以具体类型为单位进行内存分配-ma ...
 
随机推荐
- HDU1247 Hat’s Words(Trie树)
			
常规做法是枚举每个字符串每个位置,时间复杂度O(n*len*len),(建字典树O(n*len)). 然而我看这题第一眼想的是时间复杂度O(n*len)的算法..就是建正反两棵字典树,每个字符串跑分别 ...
 - velocity 判断 变量 是否不是空或empty
			
原先的 #if($mobile) 这种写法是不准确的 ,请换成 "$!{ mobile}"!="" 说明 : #if($mobile) 这种写法 只能 ...
 - [Java] StringBuffer类
			
http://www.cnblogs.com/springcsc/archive/2009/12/03/1616330.html 注: StringBuffer类和String一样,也用来代表字符串, ...
 - 【BZOJ】1087: [SCOI2005]互不侵犯King(状压dp)
			
http://www.lydsy.com:808/JudgeOnline/problem.php?id=1087 状压dp是第一次写啊,我也是才学TAT.状压dp一般都用一个值表示集合作为dp的一个状 ...
 - COJ980 WZJ的数据结构(负二十)
			
试题描述 在Bytemountains有N座山峰,每座山峰有他的高度h_i.有些山峰之间有双向道路相连,共M条路径,每条路径有一个困难值,这个值越大表示越难走,现在有Q组询问,每组询问询问从点v开始只 ...
 - oracle系列--第五篇 PLSQL连接本地的Oracle数据库
			
这篇blog主要是针对新手,我也是个新手:) 我们把oracle成功的安装在了我们的计算机上面,那我们如何才能将PLSQL developer连 接到本地的oracle呢? 首先,我们必须有下面步准备 ...
 - ubuntu 14.04 https 形式安装docker 私有库 harbor
			
起始目录/root,root 登陆后,直接在该目录进行下面的命令 下载harbor 预编译包 0.4.5 准备通过域名 reg.server.com 来访问镜像库所以需要在/etc/hosts 文件中 ...
 - Ubuntu根目录下各文件夹的功能详细介绍
			
Ubuntu的根目录下存在着很多的文件夹,但你知道他们都存放着哪些文件呢?这些是深入了解Ubuntu系统必不缺少的知识,本文就关于此做一下介绍吧. /bin/ 用以存储二进制可执行命令文件. / ...
 - 提升 web 应用程序的性能(一)
			
提升 web 应用程序的性能,找出瓶颈,加快客户端内容的速度. 作为 web 用户,我们知道页面加载或刷新的速度对其成功至关重要.本文将帮助您更好地理解影响 web 应用程序性能的因素.学 ...
 - Qt OpenCV Support Image Type 支持读写的图像格式
			
Qt 支持的图片格式如下: Format Description Qt's support BMP Windows Bitmap Read/write GIF Graphic Interchange ...