传统数组有着如下缺点:
- 数组的长度必须事先确定,而且只能是常整数,不能是变量
int a[5];//正确
int len = 5; int a[len];//错误
传统形式定义的数组,该数组的内存程序员无法手动释放,在一个函数运行期间,系统为该函数中数组所分配的空间会一直存在,直到该函数运行完毕时,数组的空间才会被系统释放。
数组的长度一旦定义,其长度就不能更改,数组的长度不能在函数运行的过程中动态的扩充或缩小。
A函数定义的数组,在A函数运行期间可以被其它函数使用,但A函数运行完毕之后,A函数中的数组将无法被其他函数使用。也就是说,传统方式定义的数组不能跨函数使用。
而动态内存分配就很好解决了传统数组的这4个缺陷,传统数组也叫静态数组。
动态数组的构造
假设动态构造一个int型一维数组