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 函数名 查看

 

posted on 2017-10-25 18:06  标配的小号  阅读(251)  评论(0编辑  收藏  举报

导航