动态分配

本文探讨了在编程中静态声明变量的局限性,并介绍了动态内存分配的概念。动态内存分配允许程序在运行时根据需要分配任意大小的内存,解决了预先确定数组大小的问题。文章还讨论了动态分配内存对于处理不确定长度的数据结构的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

所有的变量使用到这一点,在本教程中有一个共同点:该变量必须先声明在编译的时候。这导致了两个问题:第一,很难有条件地声明一个变量,把它在一个if语句块之外(在这种情况下,它会超出范围时,块的结束)。第二,所有数组的大小必须决定在运行程序之前。例如以下是不合法的
cout << "How many variables do you want? ";
int nVars;
cin >> nVars;

int anArray[nVars]; // wrong!  The size of the array must be a constant

然而,在许多情况下,它会有用能的大小或调整阵列并正在运行的程序。例如,我们可能需要使用一个字符串,牵着别人的名字,但我们不知道多久,他们的名字是直到他们进入它。我们可能要在数的记录从磁盘读取,但我们事先不知道有多少记录。或者我们可以创建一个游戏,一个怪物追逐的球员数量可变的。

如果我们不得不宣布一切大小在编译的时候,我们所能做的就是尽力猜测的最大数量的变量,我们需要和希望的,足够的:

char szName[25]; // let's hope their name is less than 25 chars!
Record asRecordArray[500]; // let's hope there are less than 500 records!
Monster asMonsterArray[20]; // 20 monsters maximum

他是一个贫穷的解决方案有以下几个原因。首先,它会导致浪费内存如果变量实际上并没有用。例如,如果我们分配25个字符每名称,但名称平均只有12个字符长,我们分配在两次,我们真正需要的!第二,它可以导致人为的限制和/或缓冲区溢出。当用户试图在600个记录从磁盘读取?因为我们只分配了500的空间,我们可以给用户一个错误,只看前500条记录,或(在最坏的情况下,我们根本没有处理这种情况),我们的记录,我们的程序缓冲区溢出崩溃。

幸运的是,这些问题是容易解决的问题,通过动态内存分配。动态内存分配允许我们将任何大小的记忆在我们需要的时候我们需要它。

单变量的动态分配

分配一个单变量的动态,我们使用标量(非数组)的新的算子形式:


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值