`
gqf2008
  • 浏览: 77137 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

malloc()与 alloc()区别

阅读更多

C语言跟内存分配方式

(1) 从静态存储区域分配。内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在。例如全局变量,static变量。

(2) 在栈上创建。在执行函数时,函数内局部变量的存储单元都可以在栈上创建,函数执行结束时这些存储单元自动被释放。栈内存分配运算内置于处理器的指令集中,效率很高,但是分配的内存容量有限。

(3)从堆上分配,亦称动态内存分配。程序在运行的时候用malloc或new申请任意多少的内存,程序员自己负责在何时用free或delete释放内存。动态内存的生存期由我们决定,使用非常灵活,但问题也最多

C语言跟内存申请相关的函数主要有 alloca,calloc,malloc,free,realloc,sbrk等.

其中alloca是向栈申请内存,因此无需释放. malloc分配的内存是位于堆中的,并且没有

初始化内存的内容,因此基本上malloc之后,调用函数memset来初始化这部分的内存空间.

calloc则将初始化这部分的内存,设置为0. 而realloc则对malloc申请的内存进行大小的

调整.申请的内存最终需要通过函数free来释放. 而sbrk则是增加数据段的大小;

malloc/calloc/free基本上都是C函数库实现的,跟OS无关.C函数库内部通过一定的

结构来保存当前有多少可用内存.如果程序malloc的大小超出了库里所留存的空间,那么

将首先调用brk系统调用来增加可用空间,然后再分配空间.free时,释放的内存并不立即

返回给os,而是保留在内部结构中. 可以打个比方: brk类似于批发,一次性的向OS申请大

的内存,而malloc等函数则类似于零售,满足程序运行时的要求.这套机制类似于缓冲.

使用这套机制的原因: 系统调用不能支持任意大小的内存分配(有的系统调用只支持固定大小以及其倍数的内存申请,这样的话,对于小内存的分配会造成浪费; 系统调用申请内存代价昂贵,涉及到用户态和核心态的转换.

函数malloc()和calloc()都可以用来分配动态内存空间,但两者稍有区别。   

    malloc()函数有一个参数,即要分配的内存空间的大小:   

    Void *malloc(size_t size);  

    calloc()函数有两个参数,分别为元素的数目和每个元素的大小,这两个参数的乘积就是要分配的内存空间的大小:   

    void *calloc(size_t numElements,size_t sizeOfElement);

    如果调用成功,函数malloc()和calloc()都将返回所分配的内存空间的首地址。

    malloc() 函数和calloc ()函数的主要区别是前者不能初始化所分配的内存空间,而后者能。如果由malloc()函数分配的内存空间原来没有被使用过,则其中的每一位可能都是 0;反之,如果这部分内存空间曾经被分配、释放和重新分配,则其中可能遗留各种各样的数据。也就是说,使用malloc()函数的程序开始时(内存空间还 没有被重新分配)能正常运行,但经过一段时间后(内存空间已被重新分配)可能会出现问题。

    calloc() 函数会将所分配的内存空间中的每一位都初始化为零,也就是说,如果你是为字符类型或整数类型的元素分配内存,那么这些元素将保证会被初始化为零;如果你是为指针类型的元素分配内存,那么这些元素通常(但无法保证)会被初始化为空指针;如果你是为实数类型的元素分配内存,那么这些元素可能(只在某些计算机中)会被初始化为浮点型的零。

    malloc() 函数和calloc ()函数的另一点区别是calloc()函数会返回一个由某种对象组成的数组,但malloc()函数只返回一个对象。为了明确是为一个数组分配内存空 间,有些程序员会选用calloc()函数。但是,除了是否初始化所分配的内存空间这一点之外,绝大多数程序员认 为以下两种函数调用方式没有区别:

    calloc(numElements ,sizeOfElement);

    malloc(numElements *sizeOfElement) ;

    需要解释的一点是,理论上(按 照ANSIC标准)指针的算术运算只能在一个指定的数组中进行,但是在实践中,即使C编译程序或翻译器遵循这种规定,许多C程序还是冲破了这种限制。因 此,尽管malloc()函数并不能返回一个数组,它所分配的内存空间仍然能供一个数组使用(对realloc()函数来说同样如此,尽管它也不能返回一 个数组)。

    总之,当你在calloc()函数和malloc()函数之间作选择时,你只需考虑是否要初始化所分配的内存空间,而不用考虑函数是否能返回一个数组。

    当程序运行过程中malloc了,但是没有free的话,会造成内存泄漏.一部分的内存没有

被使用,但是由于没有free,因此系统认为这部分内存还在使用,造成不断的向系统申请内

存,是的系统可用内存不断减少.但是,内存泄漏仅仅指程序在运行时,程序退出时,OS将回

收所有的资源.因此,适当的重起一下程序,有时候还是有点作用.

分享到:
评论

相关推荐

    malloc 与new的区别

    而C++则通过关键字new和delete来实现这一功能,它们与C语言中的malloc和free既有相似之处也有明显的区别。本文将对malloc和new的区别进行详细解读,包括它们的属性、参数、返回类型、自定义类型处理、内存区域、分配...

    alloc.h头文件

    《alloc.h头文件详解及其与malloc.h的区别》 在编程世界中,头文件扮演着至关重要的角色,它们包含了函数声明、常量定义以及各种类型声明等,为源代码提供了必要的接口信息。今天我们要讨论的是非标准头文件`alloc....

    linux c内存分配函数介绍

    在Linux C中,内存分配函数是非常重要的一部分,例如malloc, kmalloc, zalloc等等。这些函数都有其特点和使用场景。 首先,让我们来看一下typedef和#define的区别。typedef只是为了增加可读性而为标识符另起的新...

    内存分配与释放 alloc,free

    内存分配与释放是计算机编程中的基础操作,尤其是在C/C++这样的低级语言中,程序员需要直接处理内存的申请和释放。在操作系统中,内存管理是一个关键的子系统,它负责为进程分配内存,并在不再需要时回收内存。本文...

    new 和 malloc区别.docx

    ### 新与malloc的区别详解 #### 一、概述 在C++编程中,动态内存管理是不可或缺的一部分,其中`new`和`malloc`是最常用的两种内存分配方式。虽然它们都能实现动态内存分配的功能,但在实现机制、语法使用以及功能...

    alloc-release-0.7.1.tar.gz~

    综上所述,`alloc-release-0.7.1.tar.gz~`是一个与内存管理相关的软件组件,可能是`mpush`项目的一部分,提供高效的内存分配服务,并在0.7.1版本中进行了改进或增强。深入研究这个项目源码,可以帮助我们理解内存...

    alloc_h.rar

    "alloc_h.rar"的标题暗示了我们可能正在处理一个与内存分配相关的头文件,这通常包含函数声明和宏定义,用于在程序运行时请求、释放或管理内存。在C和C++中,内存分配分为静态分配、栈分配和堆分配三种主要类型。 1...

    基于malloc与free函数的实现代码及分析

    《malloc与free函数的实现与分析》 在C语言中,malloc与free是进行动态内存管理的关键函数。本文将深入探讨这两个函数的实现原理,帮助读者理解内存分配和释放的内部机制。 首先,malloc函数负责在运行时为程序...

    malloc函数的声明

    使用`malloc()`函数时,一般建议与`sizeof`运算符配合,确保分配的内存大小与实际需要的数据类型匹配。`sizeof`运算符用于获取C语言中数据类型或变量所占的字节数。例如,如果你需要分配一个`int`类型的变量,可以...

Global site tag (gtag.js) - Google Analytics