• C语言:动态内存分配(2)


    calloc
    C语言还提供了一个函数叫calloc,calloc函数也用来动态内存分配。原型如下:

    void* calloc(size_t num,size_t size);
    需引用头文件#include

    函数的功能是为num这个大小为size的元素开辟一块空间,并且把空间的每个字节初始化为0.
    与函数malloc的区别只在于calloc会在返回地址之前把申请的空间的每个字节初始化为全0.

    实例:

    int*p=(int*)calloc(10,sizeof(int));
    if(p==NULL)
    {
        printf("%s\n",strerror(errno));
    }
    else
    {
        int i=0;
        for(i=0;i<10;i++)
        {
            printf("%d ",*(p+i));
        }
    }
    //free释放动态开辟空间
    free(p);
    p=NULL;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    malloc与calloc相比,malloc效率高点,但是不会初始化;calloc效率低点,但是会给你初始化为0,未来看你是否想初始化再选择使用哪个函数

    realloc:(调整动态开辟内存空间的大小)

    realloc函数的出现让动态内存管理更加灵活。
    有时会我们发现过去申请的空间太小了,有时候我们又会觉得申请的空间过大了,
    那为了合理的时候内存,我们一定会对内存的大小做灵活的调整。那realloc函数就可以做到对动态开辟内存大小的调整

    void* realloc(void* ptr, size_t size);

    1.ptr是要调整的内存地址
    2.size调整之后新大小
    3.返回值为调整之后的内存起始位置。
    4.这个函数调整原内存空间大小的基础上,还会将原来内存中的数据移动到新的空间。
    5.realloc在调整内存空间的是存在两种情况

    rea11oc使用的注意事项:
    1.如果p指向的空间之后有足够的内存空间可以追加,则直接追加,后返回p
    2.如果p指向的空间之后没有足够的内存空间可以追加,则realloc函数会重新找一个新的内存区域,
    开辟一块满足需求的空间,并且把原来内存中的数据拷贝回来,释放旧的内存空间,最后返回新开辟的内存空间地址
    3.得用一个新的变量来接受realloc函数的返回值

        int*k=(int*)malloc(20);
        if(k==NULL)
        {
            printf("%s\n",strerror(errno));
        }
        else
        {
            int i=0;
            for(i=0;i<5;i++)
            {
                *(k+i)=i;
            }
        }
        //假设这里20个字节不能我们满足的使用了
        //希望有40个字节的空间
        //这里就可以使用realloc来调整动态开辟的内存
        int*ptr=realloc(k,40);
        //万一开辟的内存空间太大,开辟失败会返回一个空指针
        //空指针再返回给原地址就完蛋了,所以用一个新变量来接收一下比较好
        if(ptr!=NULL)
        {
            k=ptr;
            int i=0;
            for(i=5;i<10;i++)
            {
               *(k+i)=i;
            }
            for(i=0;i<10;i++)
            {
               printf("%d ",*(k+i));
            }
        }
        free(k);
        k=NULL;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
  • 相关阅读:
    Vue-cli全局配置整理
    五年数据库专家,带你深入高性能 MySQL 架构系统,不要等到面试再追悔莫及
    matalb生成符合泊松分布的随机数,并进行测试是否符合
    dubbo2.7时间轮的应用
    Java 继承(extends)
    ThingsBoard Iot gatway Modbus 连接器配置 第一部分
    设计模式——装饰器模式
    Ansible 快速入门
    IS-IS实验总结 (下)
    你的小程序为什么还是不被用户看好?
  • 原文地址:https://blog.csdn.net/qq_57430594/article/details/128158099