//申请空间
int array[3];
int *array = new int[10];//动态分配
//初始化
int array[3] = {1, 2, 3};
memset(array,0,sizeof(array));//或者 memset(array,0,10*sizeof(int));
for(int i = 0; i < 3; ++i) array[i] = i + 1;
//撤销
delete[] array;
array = NULL; //释放空间后p[i]不会自动指向NULL值,需要我们手动赋值
1.3 二维数组
1.3.1 三种数组空间申请
//第一种
int **array;
array = new int *[10];
for(int i = 0; i<10; i++)
array[i] = new int [5];
//第二种
int (*array)[n] = new int[m][n];//注意这里的m和n必须是const,不属于动态分配
//第三种
int *array[10];
for(int i = 0; i < 10; ++i)
array[i] = new int[5];
1.3.2 两种初始化
//第一种 遍历
for(int i = 0; i < 10; i++){
for(int j = 0; j < 5; ++j)
array[i][j] = 0;
}
//第二种 memset
for(int i = 0; i < 10; i++){
array[i] = new int[5];
memset(array[i], 0, 5 * sizeof(int)); //memset只能作用于一个一维数组 *array
}
1.3.3 释放空间
for (int i = 0; i < 10; i ++) {
delete[] array[i];
array[i] = NULL;
}
delete [] array;
array = NULL;
二、标准库array类
跟普通数组一样高效,但更安全
2.1 example
#include <array>
using namespace std;
int main(){
array<int, 4> ar;
ar.fill(5);
for(int i = 0; i < 4; ++i)
cout << ar[i] << " ";
cout << endl; //5 5 5 5
}