malloc,calloc,alloca和free函数
void *malloc(size_t size)因为返回类型为空,所以可以赋值到任何类型指针,其分配的空间大小为size,返回新分配内存地址的起始处的指针,其所分配的内存未经初始化,若分配失败返回NULL
void free(void *ptr)
虽然在程序结束后,程序会自动释放内存,但最好还是用free()显式释放内存资源
[root@bogon code]# cat d.c
#include<stdio.h>
#include<stdlib.h>
#include<error.h>
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.out
malloc 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<stdio.h>
#include<stdlib.h>
#include<error.h>
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.out
calloc 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 函数名 查看