使用realloc函数容易出现的陷阱(内存泄露)

realloc函数原型 : void *realloc(void *_ptr, size_t size);

realloc函数原理:当申请的空间不够我们使用时,需要扩容。

假设原空间大小为如下图所示

1.原空间已满,需要realloc申请更大的空间,若原空间后还有我们所需的足够空间则直接往后申请空间。如红色图示:

2.原空间已满,需要realloc申请更大的空间,若原空间后没有我们所需的足够空间,则需要另外开辟黑色空间加上红色空间大小的内存。并且将原黑色空间里的数据复制到新申请空间中,把原黑色空间内存释放掉。

3.原空间后没有足够空间,并且其他区域也无法申请空间,这时就会导致申请失败。

int main()
{
    int* ptr = (int*)malloc(sizeof(int) * 10);//1
    assert(ptr != NULL);
    if (ptr == NULL)
        return 1;
    for (int i = 0;i < 10;i++)
    {
        ptr[i] = i;
    }                                         //2
    int* ptr = (int*)realloc(ptr, sizeof(int) * 20);//3
    assert(ptr != NULL);
    if (ptr == NULL)
     { 
        return 1;
    for (int i = 10;i < 20;i++)
    {
        ptr[i] = i;                            //4
    }
    free(ptr);
    return 0;
}

上面代码中1处我们申请了10个字节大小的空间,2处将1-9分别赋值给数组,3处扩容了十个字节大小的空间,4处将10-19赋值给数组。

但是需要注意的是:在3处当我们realloc申请空间失败的时候,将返回NULL,此时我们将空指针赋值给了ptr,但是在1处申请的空间没有指针指向,所以那段空间无法被free释放,此时便会造成内存泄漏。

修改如下:

int main()
{
    int* ptr = (int*)malloc(sizeof(int) * 10);//1
    assert(ptr != NULL);
    if (ptr == NULL)
        return 1;
    for (int i = 0;i < 10;i++)
    {
        ptr[i] = i;
    }                                         //2
    int* p = (int*)realloc(ptr, sizeof(int) * 20);//3
    
    assert(p != NULL);
    if (p == NULL)
     {
       free(ptr);                              //6
       return 1;
     }
     ptr=p;                                       //5
    for (int i = 10;i < 20;i++)
    {
        ptr[i] = i;                            //4
    }
    free(ptr);
    return 0;
}

这样在6处我们借助中间变量存取realloc申请空间返回的地址,即使realloc申请失败也可以将原来malloc申请的空间释放,不会导致内存泄漏。

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
realloc函数用于重新分配已分配内存块的大小。它的语法如下: ```c void *realloc(void *ptr, size_t size); ``` 其中,ptr是一个指向已分配内存块的指针,size是需要重新分配的内存块的新大小。该函数的返回值是指向新分配内存块的指针。 使用realloc函数时需要注意以下几点: 1. 如果ptr为NULL,则该函数等同于malloc(size),即重新分配一个新的内存块。 2. 如果size为0,则该函数等同于free(ptr),即释放已分配的内存块。 3. 如果realloc函数无法重新分配内存块,则它会返回NULL,原有的内存块不会被释放。 4. 如果新分配的内存块大小比原来的内存块大小小,则新分配的内存块中可能会出现未定义的行为,因此需要小心使用。 以下是一个示例代码: ```c #include <stdio.h> #include <stdlib.h> int main() { int *p = (int*)malloc(5 * sizeof(int)); if (p == NULL) { printf("Failed to allocate memory\n"); return 1; } for (int i = 0; i < 5; i++) { p[i] = i; } p = (int*)realloc(p, 10 * sizeof(int)); if (p == NULL) { printf("Failed to reallocate memory\n"); return 1; } for (int i = 5; i < 10; i++) { p[i] = i; } for (int i = 0; i < 10; i++) { printf("%d ", p[i]); } free(p); return 0; } ``` 该程序首先分配了一个包含5个int类型元素的内存块,然后使用realloc函数将其重新分配为一个包含10个int类型元素的内存块,并将新增的5个元素赋值为5到9。最后,程序释放了已分配的内存块。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值