一、二维数组存放方式
二维数组中元素排列的顺序是按行存放的,即在内存中先顺序存放第一行的元素,再存放第二行的元素...
二、二维数组作为函数参数
二维数组作为函数参数,实参可以直接使用二维数组名,在被调用函数中对形参数组定义可以指定所有维数的大小,也可以省略第一维的大小说明,如:
void f(int a[3][4]);
void f(int a[][4]);
它们是合法且等价,也可以使用如下形式:
void f(int (*a)[4]);
但不能省略第二维的大小,如下面的定义是不合法的,编译时会出错:
void f(int a[][]);
void f(int a[3][]);
因为从实参传递来的是数组的起始地址,如果在形参中不说明列数,编译器将无法定位元素的的位置。
三、各个维数不固定的二维数组
如果二维数组的各个维数不固定,我们将不能使用以上定义方法,可以通过以下2种简单的方法实现。
1、将二维数组当一维数组操作
被调用函数定义:
void f(int *a,int n);
实参传递:
int a[3][4];
f(*a,12);
2、手工转变寻址方式
被调用函数定义:
void f(int **a,int m,int n);
实参传递:
int a[3][4];
f((int **)a,3,4);
这样在被调用数组中对对元素a[i][j]的访问可以使用如下形式:
*((int *)a+n*i+j);
注意不能使用a[i][j]来直接访问,因为编译器无法为其定位,若直接使用a[i][j]在ubuntu上会报“段错误(核心已转储)”的错误,段错误(核心已转储)我之前的博客提到过。