realloc函数心得

realloc 可以对给定的指针所指的空间进行扩大或者缩小,原有内存的中内容将保持不变。当然,对于缩小,则被缩小的那一部分的内容会丢失。

 

realloc 并不保证调整后的内存空间和原来的内存空间保持同一内存地址。相反,realloc 返回的指针很可能指向一个新的地址: 

    因为realloc是从堆上分配内存的,当扩大一块内存空间时, realloc直接从堆上现存的数据后面的那些字节中获得附加的字节;但如果数据后面的字节不够的话,那么就使用堆上第一个有足够大小的自由块,现存的数据然后就被拷贝至新的位置,而老块则放回到堆上。

在代码中,如果我们采用i = (int*)realloc(i, 2*sizeof(int))的重新分配内存方式,有以下两种情况:

1.分配成功,返回void*指针:realloc返回值如果与前面malloc的值不同,那么realloc函数完成后,i指向的旧内存自动free掉。
    2.
分配失败,返回NULL值:此时,i原来指向的内存还没有被free掉,而现在又找不到地址,这样就出现memory leak了。

 

    解决办法:定义另一个指针j用于接收realloc返回值,判断是否成功,成功则将j赋给i

 

 

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
realloc函数用于重新分配已经分配内存的大小。它接受两个参数:指向已分配内存的指针和新的内存大小。 realloc的使用方法如下: ```c#include <stdlib.h> void* realloc(void* ptr, size_t size); ``` 其中,ptr是指向先前通过malloc、calloc或realloc分配的内存块的指针,size是新的内存大小。 realloc函数会根据新的大小重新分配内存,如果新的大小小于先前分配的大小,那么多余的部分会被截断。如果新的大小大于先前分配的大小,那么额外的空间将会被初始化为未定义的值。 realloc函数返回一个指针,指向重新分配后的内存块。如果重新分配失败,它将返回NULL,并且原来的内存块保持不变。 使用realloc时需要注意以下几点: - 如果realloc返回NULL,说明内存分配失败,原来的内存块仍然有效,应该避免使用已经重新分配失败的内存块。 - 如果ptr是NULL,则realloc的行为相当于malloc(size)。 - 如果size为0并且ptr不是NULL,则realloc的行为相当于free(ptr)。 下面是一个示例代码,演示了如何使用realloc函数: ```c#include <stdio.h> #include <stdlib.h> int main() { int* numbers = malloc(5 * sizeof(int)); // 分配5个整数的内存空间 // 使用realloc函数将内存大小调整为10个整数 int* new_numbers = realloc(numbers,10 * sizeof(int)); if (new_numbers != NULL) { numbers = new_numbers; // 更新指针 // 输出调整后的数组大小 printf("数组大小为:%lu\n", sizeof(numbers) / sizeof(int)); free(numbers); //释放内存 } else { printf("内存分配失败\n"); } return0; } ``` 这是一个简单的示例,展示了realloc函数的基本使用方法。在实际应用中,应该根据具体需求来判断何时使用realloc函数
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值