使用数组指针,分配一个指针数组,将其首地址保存在b中,然后再为指针数组的每个元素分配一个数组
int **b=new int*[row]; //分配一个指针数组,将其首地址保存在b中
for(i=0;i<row;i++) //为指针数组的每个元素分配一个数组
b[i]=new int[col];
该方法定义的动态二维数组的释放需先释放指针数组的每个元素指向的数组,然后再释放该指针数组:
for(i=0;i<row;i++)
{
delete [col]b[i];
b[i]=NULL;
}
delete [row]b;
int **b=new int*[row]; //分配一个指针数组,将其首地址保存在b中
for(i=0;i<row;i++) //为指针数组的每个元素分配一个数组
b[i]=new int[col];
该方法定义的动态二维数组的释放需先释放指针数组的每个元素指向的数组,然后再释放该指针数组:
for(i=0;i<row;i++)
{
delete [col]b[i];
b[i]=NULL;
}
delete [row]b;
b=NULL;
/
以上程序来源于网络,可以动态设置二维数组的大小。但需要十分注意的是由于这个二维数组的空间是分row次new申请的,所以该二维数组的地址不是连续的,而直接定义数组时申请的地址空间是连续的。因此实际应用时应十分注意这个区别。比如我将位图数据复制到上面程序的二维数组b[row][col]时,如果按照&b[0][0]这个起始地址写数据到bmp文件时结果是错的,因为写文件时地址是连续的,而实际地址是不连续的。
在这种情况下可以直接申请一个连续的,足够大的地址
int* b=new int[row*col];//要读取b[m][n]相当于读取b[m*row+col],由于只申请一次空间,因此该空间是连续的