【C语言】动态内存管理用realloc管理更灵活

realloc------动态内存空间管理更灵活

为了合理使用内存,我们会对内存的大小做灵活的调整。那 realloc 函数就可以做到对动态开辟内存大小的调整。

头文件:# include<stdlib.h>

**void * realloc (**要调整的内存地址 , 调整之后新大小 )

void * realloc ( void * ptr , size_t size )

注意:

  • 返回值为调整之后的内存起始位置。
  • 这个函数调整原内存空间大小的基础上,还会将原来内存中的数据移动到 新的空间。· realloc在调整内存空间的是存在两种情况:

情况1:原有空间之后有足够大的空间

要扩展内存就直接原有内存之后直接追加空间,原来空间的数据不发生变化。

情况2:原有空间之后没有足够多的空间

在堆空间上另找一个合适大小的连续空间来使用。这样函数返回的是一个新的内存地址。

由于上述的两种情况,realloc函数的使用就要注意一些。

复制代码
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<errno.h>

int main()
{
	int* p = (int*)malloc(5 * sizeof(int));
	if (p == NULL)
	{
		perror("malloc");
	}
	int i = 0;
	for (i = 0;i < 5;i++)
	{
		*(p + i) = i + 1;
	}

	//不够用,增加五个内存空间
	int* ptr = (int*)realloc(p, 10*sizeof(int));
	if (ptr != NULL)
	{
		p = ptr;
	}

	// 初始化新增加的内存空间
	for (i = 5; i < 10; i++)
	{
		*(p + i) = i + 1;
	}

	//打印
	for (i = 0;i < 10;i++)
	{
		printf("%d ", *(p + i));
	}

	//释放空间
	free(p);
	p = NULL;

	return 0;
}

输出:

1 2 3 4 5 6 7 8 9 10

相关推荐
共享家95271 分钟前
排序算法实现:插入排序与希尔排序
c语言·开发语言·数据结构·算法·排序算法
记得早睡~5 分钟前
leetcode501-二叉搜索树中的众数
javascript·数据结构·算法·leetcode
被AI抢饭碗的人10 分钟前
算法题(102):八皇后
算法·深度优先
无敌的牛15 分钟前
算法刷题力扣
算法·leetcode·职场和发展
江沉晚呤时15 分钟前
深入解析 .NET Core 垃圾回收(GC):概念、工作原理与优化策略
java·jvm·算法·c#·asp.net·.netcore·net
uhakadotcom18 分钟前
CUDA编程入门:加速计算的强大工具
算法·面试·架构
wgc2k26 分钟前
吴恩达机器学习笔记复盘(六)梯度下降算法
笔记·算法·机器学习
朽棘不雕33 分钟前
C语言复习笔记--数组
c语言·笔记
niuTaylor39 分钟前
Linux驱动开发实战之SRIO驱动(一)
linux·c语言·开发语言·驱动开发
jz_ddk1 小时前
实战:Windows环境下C语言串口通信与多线程编程
c语言·windows·单片机·测试用例