• 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
    ");
        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
    ");
        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 函数名 查看

  • 相关阅读:
    bzoj3306: 树(dfs序+倍增+线段树)
    bzoj1969: [Ahoi2005]LANE 航线规划(树链剖分)
    Codeforces 578B. "Or" Game(思维题)
    bzoj3251: 树上三角形(思维题)
    bzoj2006: [NOI2010]超级钢琴(堆+RMQ)
    bzoj4165: 矩阵(堆+hash)
    bzoj3007: 拯救小云公主(二分+并查集)
    Codeforces 582C. Superior Periodic Subarrays(数学+计数)
    Codeforces 585E. Present for Vitalik the Philatelist(容斥)
    Codeforces 585D. Lizard Era: Beginning(meet in the middle)
  • 原文地址:https://www.cnblogs.com/biaopei/p/7730626.html
Copyright © 2020-2023  润新知