malloc、calloc、realloc三者的区别

1、malloc

作用:分配内存块

原型:void *malloc(size_t size);size表示要分配的字节数

返回值:返回一个指向所分配空间的void指针,如果没有足够的内存可用,则返回NULL。

如果要返回一个指向特定类型的指针,则在返回值上用一个类型转换。例如:

char* p;

p=(char*)malloc(20);

如果size是0,则malloc在堆中分配一个长度为0的项,并且返回一个指向那项的有效指针。例如:

int *p1=(int*)malloc(0) //ok,p1!=NULL

我们通常要检查malloc返回的值,即使需要分配的内存块非常小。

因为校准和维护信息的原因,所分配的内存可能比size bytes要大。

2、calloc

作用:在内存中分配一个元素被初始化为0的数组。

原型:void *calloc(size_t num,size_t size);num表示元素的个数,size表示每个元素的大小。

返回值:返回一个指向所分配空间的void指针。

如果要返回一个指向特定类型的指针,则在返回值上用一个类型转换。例如:

char* p;

p=(char*)calloc(20,sizeof(char));

3、realloc

作用:重新分配内存块

原型:void *realloc(void* memblock,size_t size);memblock指向原先分配的内存块,size表示新的内存块的字节大小。

返回值:返回一个指向重新分配(可能移动了)的内存块的大小。例如:

char* p;

p=(char*)malloc(sizeof(char)*20);

p=(char*)realloc(p,sizeof(char)*40);

如果要返回一个指向特定类型的指针,则在返回值上用一个类型转换。

如果size是0并且缓冲区参数不是NULL,或者没有足够可用的内存去扩展给定的大小,那么将返回NULL。对于前者,原先的内存将被释放,对于后者,原先的内存将保持不变。

如果memblock是NULL,那么realloc就和malloc的行为一样分配一个新的size字节大小的块。如果memblock不是NULL,那么它应该是一个早先由malloc或者realloc返回的指针。例如:

int *p3=(int*)realloc(NULL,10*sizeof(int));//ok,p3!=NULL

由于新的内存块可能在一个新的内存位置,所以由realloc返回的指针不能保证和所传递的memblock是同一个指针。

参数size给出了新的内存块的大小,以字节为单位。块的内容保持不变直到新的和旧的块的大小变小,虽然新的内存块可能在一个不同的位置。



时间: 2024-10-23 05:24:47

malloc、calloc、realloc三者的区别的相关文章

malloc,calloc,realloc三者的区别

malloc,calloc,realloc三者都可以运用与动态分配数组. malloc:用malloc必须要自己初始化,可以用memset(arr,0,cnt*sizeof(int)) calloc:会在分配时自动初始化,不用再单独初始化 realloc:用于对原先空间扩容  arr = (int *)realloc(arr,(10+5)*sizeof(int));//10为原有数组大小,5为扩容大小: 三个函数的申明分别是: void* malloc(unsigned size); void*

C:malloc/calloc/realloc/alloca内存分配函数

原文地址:http://www.cnblogs.com/3me-linux/p/3962152.html calloc(), malloc(), realloc(), free(),alloca() 内存区域可以分为栈.堆.静态存储区和常量存储区,局部变量,函数形参,临时变量都是在栈上获得内存的,它们获取的方式都是由编译器自动执行的. 利用指针,我们可以像汇编语言一样处理内存地址,C 标准函数库提供了许多函数来实现对堆上内存管理,其中包括:malloc函数,free函数,calloc函数和rea

malloc/calloc/realloc/alloca内存分配函数

calloc(), malloc(), realloc(), free(),alloca() 内存区域可以分为栈.堆.静态存储区和常量存储区,局部变量,函数形参,临时变量都是在栈上获得内存的,它们获取的方式都是由编译器自动执行的. 利用指针,我们可以像汇编语言一样处理内存地址,C 标准函数库提供了许多函数来实现对堆上内存管理,其中包括:malloc函数,free函数,calloc函数和realloc函数.使用这些函数需要包含头文件stdlib.h. 四个函数之间的有区别,也有联系,我们应该学会把

malloc calloc realloc alloca

本文来至http://www.cnblogs.com/jyaray/archive/2010/06/04/1751775.html 内存区域可以分为栈.堆.静态存储区和常量存储区,局部变量,函数形参,临时变量都是在栈上获得内存的,它们获取的方式都是由编译器自动执行的. 利用指针,我们可以像汇编语言一样处理内存地址,C 标准函数库提供了许多函数来实现对堆上内存管理,其中包括:malloc函数,free函数,calloc函数和realloc函数.使用这些函数需要包含头文件stdlib.h. 四个函数

calloc、malloc、realloc函数的区别及用法

/* 需要手动计算内存大小,未初始化 */ int *p = (int *)malloc(20 * sizeof(int)); /* 不需要手动计算内存大小,初始化为0 */ int *q = (int *)calloc(20, sizeof(int)); /* 动态内存 扩大/缩小 * 1.成功分配: * 1.1 返回地址相同, 原内存后 有 空余内存,返回原来指针的地址: * 1.2 返回地址不同, 原内存后 没有 空余内存,新分配一块儿内存,并把原来的内存内容拷贝过来,原来的内存释放掉:

Linux C 堆内存管理函数malloc(),calloc(),realloc(),free()详解

C 编程中,经常需要操作的内存可分为下面几个类别: 堆栈区(stack):由编译器自动分配与释放,存放函数的参数值,局部变量,临时变量等等,它们获取的方式都是由编译器自动执行的 堆区(heap):一般由程序员分配与释放,基程序员不释放,程序结束时可能由操作系统回收(C/C++没有此等回收机制,Java/C#有),注意它与数据结构中的堆是两回事,分配方式倒是类似于链表. 全局区(静态区)(static):全局变量和静态变量的存储是放在一块儿的,初始化的全局变量和静态变量在一块区域,未初始化的全局变

malloc calloc realloc

三个函数的申明分别是: void* realloc(void* ptr, unsigned newsize); void* malloc(unsigned size); void* calloc(size_t numElements, size_t sizeOfElement); 都在stdlib.h函数库内 (1)函数malloc()        在内存的动态存储区中分配一块长度为size字节的连续区域,参数size为需要内存空间的长度,返回该区域的首地址. 需要手动清0 (2)函数call

malloc、calloc、realloc三者的差别

1.malloc 作用:分配内存块 原型:void *malloc(size_t size);size表示要分配的字节数 返回值:返回一个指向所分配空间的void指针,假设没有足够的内存可用,则返回NULL. 假设要返回一个指向特定类型的指针,则在返回值上用一个类型转换.比如: char* p; p=(char*)malloc(20); 假设size是0,则malloc在堆中分配一个长度为0的项,而且返回一个指向那项的有效指针.比如: int *p1=(int*)malloc(0) //ok,p

论C语言的malloc,calloc,new,realloc,alloca的机制和区别

最近笔试老是遇到关于C语言的malloc,new之类的内存机制问题,作为一个做java开发的程序员不免有些郁闷,驾驭不了.乘空闲下来的这些时间,好好整理下C语言中各个内存函数的简单机制,作用和区别: C语言内存分配方式 (1) 从静态存储区域分配.内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在.例如全局变量,static变量. (2) 在栈上创建.在执行函数时,函数内局部变量的存储单元都可以在栈上创建,函数执行结束时这些存储单元自动被释放.栈内存分配运算内置于处理器的指令集