程序缓冲区

这是几个原因不能解决。首先,它会导致浪费内存如果变量实际上并没有用。例如,如果我们分配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;



你可能感兴趣的:(程序缓冲区)