zoukankan      html  css  js  c++  java
  • 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 函数名 查看

  • 相关阅读:
    C#编程思路
    将字符串类型字段转为map类型字段,使用str_to_map()函数
    写hive脚本时,如果hive的过滤条件比较多。可以把过滤条件放到一个参数里。然后把参数放到过滤条件处。这样以后只需要改参数就可以了
    linux中. 路径/文件
    inner join ,left join 会导致数据发散
    如何批量按分区插入数据
    hive表添加字段后,查不出数据是咋回事?
    linux中$0的含义
    linux中的$#含义
    linux的语法
  • 原文地址:https://www.cnblogs.com/biaopei/p/7730626.html
Copyright © 2011-2022 走看看