realloc() 用法详解

原型:extern void *realloc(void *mem_address, unsigned int newsize);

语法:指针名=(数据类型*)realloc(要改变内存大小的指针名,新的大小)。

      //新的大小若小于原来的大小,原数据的末尾可能丢失(被其他使用内存的数据覆盖等)

头文件:#include <stdlib.h> 有些编译器需要#include <malloc.h>,在TC2.0中可以使用alloc.h头文件

功能:先判断当前的指针是否有足够的连续空间,如果有,扩大mem_address指向的地址,并且将mem_address返回,如果空间不够,先按照newsize指定的大小分配空间,将原有数据从头到尾拷贝到新分配的内存区域,而后释放原来mem_address所指内存区域(注意:原来指针是自动释放,不需要使用free),同时返回新分配的内存区域的首地址。即重新分配存储器块的地址。

返回值:如果重新分配成功则返回指向被分配内存的指针,否则返回空指针NULL。

注意:这里原始内存中的数据还是保持不变的。当内存不再使用时,应使用free()函数将内存块释放。

应用举例

举例1:

从这个例子可以看出realloc函数的功能。

#include<stdio.h>
#include<stdlib.h>
#define N 10000
int main()
{
	int i;
	int *pn=(int *)malloc(5*sizeof(int));
	printf("%p\n",pn);
	for(i=0;i<5;i++)
		pn[i] = i+1;

	printf("%d\n",sizeof(int));
	int *pnn=(int *)realloc(pn, N*sizeof(int));
	printf("%p\n",pnn);
	for(i=0;i<5;i++)
	printf("%3d",pnn[i]);
	
	//for(i=0;i<5;i++)
	//printf("%3d",pn[i]);
	printf("\n");
	//free(pn);
	free(pnn);
	return 0;
}
//N取值较小时,输出如下
0x12ee010
4
0x12ee010
 1  2  3  4  5

//N取值较大时,例如100000 输出如下
0xef8010
4
0x7fba7062e010
 1  2  3  4  5

详细说明及注意要点

内存分配情况

<1>如果有足够空间用于扩大mem_address指向的内存块,则分配额外内存,并返回mem_address。

这里说的是“扩大”,我们知道,realloc是从堆上分配内存的,当扩大一块内存空间时, realloc()试图直接从堆上现存的数据后面的那些字节中获得附加的字节,如果能够满足,自然天下太平。也就是说,如果原先的内存大小后面还有足够的空闲空间用来分配,加上原来的空间大小= newsize。那么就ok。得到的是一块连续的内存。

<2>如果原先的内存大小后面没有足够的空闲空间用来分配,那么从堆中另外找一块newsize大小的内存。

并把原来大小内存空间中的内容复制到newsize中。返回新的mem_address指针。(数据被移动了)。

老块被放回堆上。

若realloc成功,指向原内存地址的指针就成了悬挂指针,即指针指向了一块没有分配给用户使用的内存,如果再用该指针进行操作就可能发生意想不到的问题。所以在应用realloc函数是应当格外注意这种情况。

返回情况

返回的是一个void类型的指针:调用成功。(这就要求在你需要的时候进行强制类型转换

返回NULL:当需要扩展的大小(第二个参数)为0并且第一个参数不为NULL时。此时原内存变成“free(游离)”的了。

返回NULL:当没有足够的空间可供扩展的时候。此时,原内存空间的大小维持不变。

特殊情况

如果mem_address为NULL,则realloc()和malloc()类似。分配一个newsize的内存块,返回一个指向该内存块的指针

如果newsize大小为0,那么释放mem_address指向的内存,并返回NULL。

如果没有足够可用的内存用来完成重新分配(扩大原来的内存块或者分配新的内存块),则返回NULL。而原来的内存块保持不变。

realloc使用总结

1. realloc失败的时候,返回NULL

2. realloc失败的时候,原来的内存不改变,不会释放也不会移动,(所以使用的时候应该保留原指针,避免分配失败产生内存泄漏)

3. 假如原来的内存后面还有足够多剩余内存的话,realloc的内存=原来的内存+剩余内存,realloc还是返回原来内存的地址; 假如原来的内存后面没有足够多剩余内存的话,realloc将申请新的内存,然后把原来的内存数据拷贝到新内存里,原来的内存将被free掉,realloc返回新内存的地址

4. 如果size为0,效果等同于free()。这里需要注意的是只对指针本身进行释放,例如对二维指针**a,对a调用realloc时只会释放一维,使用时谨防内存泄露

5. 传递给realloc的指针必须是先前通过malloc(), calloc(), 或realloc()分配的

6.传递给realloc的指针可以为空,等同于malloc

  • 110
    点赞
  • 349
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
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函数。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值