这是几个原因不能解决。首先,它会导致浪费内存如果变量实际上并没有用。例如,如果我们分配25个字符每名称,但名称平均只有12个字符长,我们分配在两次,我们真正需要的!第二,它可以导致人为的限制和/或缓冲区溢出。当用户试图在600个记录从磁盘读取?因为我们只分配了500的空间,我们可以给用户一个错误,只看前500条记录,或(在最坏的情况下,我们根本没有处理这种情况),我们的记录,我们的程序缓冲区溢出崩溃。
幸运的是,这些问题是容易解决的问题,通过动态内存分配。动态内存分配允许我们将任何大小的记忆在我们需要的时候我们需要它。
单变量的动态分配
分配一个单变量的动态,我们使用标量(非数组)的新的算子形式:|
1
|
int
*pnValue = new
int ;
//
dynamically allocate an integer |
1
2
int *pnValue = new int; // dynamically allocate an integer
*pnValue = 7; // assign 7 to this integer
当我们做了一个动态分配的变量,我们需要明确告诉C++内存释放回。这是通过标量(非数组)的删除算子形式:
1
2
delete pnValue; // unallocate memory assigned to pnValue
pnValue = 0;
注意,删除操作不会删除该指针-它删除指针所指向的内存!
动态分配数组
动态数组的声明让我们运行程序时选择自己的大小。动态分配数组,我们使用新的和删除数组形式(通常称为新的[ ]和[ ]删除):
1
2
3
4
int nSize = 12;
int *pnArray = new int[nSize]; // note: nSize does not need to be constant!
pnArray[4] = 7;
delete[] pnArray;