C常用内存分配接口,malloc/calloc/realloc/alloca。

本文深入探讨了C语言中常见的内存分配接口,包括malloc用于动态分配内存,calloc用于初始化分配的内存,realloc用于调整已分配内存的大小,以及alloca在栈上进行内存分配的特点和使用场景。理解这些接口对于优化后端程序的内存使用至关重要。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

函数原型参数说明返回值说明功能特殊说明
void *malloc(size_t size);size:被分配的堆内存大小成功:分配的堆内存的起始地址
失败:NULL
内存的动态存储区中分配一个长度为size的连续空间
void *calloc(size_t numElements, size_t sizeOfElement); numElements:对象个数
sizeOfElement:单个对象大小
成功:分配的堆内存的起始地址
失败:NULL
在内存的动态存储区中分配num个长度为size的连续空间,函数返回一个指向分配起始地址的指针;如果分配不成功,返回NULL。对分配的内存空间进行清零
realloc(void *__ptr, size_t __size)__ptr:要被改变内存大小的指针名
__size:新的大小
成功:分配的堆内存的起始地址
失败:NULL
先判断当前的指针是否有足够的连续空间,如果有,扩大mem_address指向的地址,并且将mem_address返回,如果空间不够,先按照newsize指定的大小分配空间,将原有数据从头到尾拷贝到新分配的内存区域,而后释放原来mem_address所指内存区域(注意:原来指针是自动释放,不需要使用free),同时返回新分配的内存区域的首地址。即重新分配存储器块的地址。如果mem_address为NULL,则realloc()和malloc()类似。分配一个newsize的内存块,返回一个指向该内存块的指针。
如果newsize大小为0,那么释放mem_address指向的内存,并返回NULL。
如果没有足够可用的内存用来完成重新分配(扩大原来的内存块或者分配新的内存块),则返回NULL。而原来的内存块保持不变。
void * __cdecl alloca(size_t);size_t:分配栈内存的大小成功:分配的栈内存的起始地址
失败:NULL
成功:分配的栈内存的起始地址
失败:NULL
alloca是在栈空间分配内存,在调用 alloca函数返回的时候, 它分配的内存会自动释放。所以不能使用free去释放。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值