void *malloc(size_t size)因为返回类型为空,所以可以赋值到任何类型指针,其分配的空间大小为size,返回新分配内存地址的起始处的指针,其所分配的内存未经初始化,若分配失败返回NULL
void free(void *ptr)
虽然在程序结束后,程序会自动释放内存,但最好还是用free()显式释放内存资源[root@bogon code]# cat d.c#include#include #include struct studinfo{ int id; char name[20]; int age;};int main(){ struct studinfo *p; p=malloc(sizeof(struct studinfo)); if(p==NULL) perror("malloc"); else printf("malloc succeed\n"); free(p); return 0;}[root@bogon code]# gcc d.c[root@bogon code]# ./a.outmalloc succeed[root@bogon code]#
mtrace()内存分配跟踪,muntrace()取消内存分配跟踪
mcheck()和mprobe()对已分配内存块进行一致性检查
mallinfo()返回一个结构,其中包含有malloc()分配内存的各种统计数据
void *calloc(size_t numitems,size_t size)该函数用于给一组相同对象分配内存,第一个参数是对象数量,第二个参数是每个对象大小,返回的也是其分配的的内存起始处的指针,与malloc()不同,该函数会将已分配的内存初始化为0
举个例子[root@bogon code]# cat d.c#include#include #include struct studinfo{ int id; char name[20]; int age;};int main(){ struct studinfo *p; p=calloc(10,sizeof(struct studinfo)); if(p==NULL) perror("calloc"); else printf("calloc succeed\n"); free(p); return 0;}[root@bogon code]# ./a.outcalloc succeed[root@bogon code]#
应尽量避免使用calloc
调整某块内存大小 void *realloc(void *ptr,size_t size) ptr需要调整的内存块指针,size指调整的大小,错误返回NULL分配对齐的内存,起始地址要与2的整数次幂边界对齐
void *memalign(size_t boundary,size_t size) 起始地址是boundary的整数倍,分配的内存大小为size个字节,有些linux系统可能不支持该函数。在堆栈上分配内存
void *alloca(size_t size)需要头文件为alloca.h 该函数是通过增加栈帧的大小从堆栈上分配,其分配的内存不需要free()释放,也无法通过realloc()来调整其内存大小 使用alloca()分配内存相对与malloc()具有一定的优势,因为alloca分配速度快,而且alloca也不需要维护空闲内存块列表。另外,alloca分配的内存随栈帧的移除而自动释放函数的具体使用可以使用man 函数名 查看