C语言二维数组作为函数参数传递

一、二维数组存放方式


二维数组中元素排列的顺序是按行存放的,即在内存中先顺序存放第一行的元素,再存放第二行的元素...

二、二维数组作为函数参数


二维数组作为函数参数,实参可以直接使用二维数组名,在被调用函数中对形参数组定义可以指定所有维数的大小,也可以省略第一维的大小说明,如:
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上会报“段错误(核心已转储)”的错误,段错误(核心已转储)我之前的博客提到过。





评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值