C语言函数数组传递原理 c语言数组在函数中的传递( 二 )


}
void getArr(char p[]) {
int i;
for (i = 0; p[i]; i++) {
printf("%c: %d\n", p[i], p[i]);
}
}
C语言函数传递二维数组C语言如果给函数传递二维数组作为参数
先看一个传递二维数组C语言函数数组传递原理的例子C语言函数数组传递原理:
编译:
程序看着没有任何问题C语言函数数组传递原理,但是编译器通不过 , 报错在处理二维数组参数a的时候,类型不兼容 。
C语言里面对二维数组的存储是按照一维数组来处理的,二维数组按照行展开的方式按顺序存储,例如在上面的例子中:
二维数组a的定义:
它等同于一维数值的定义:
因为他们的空间存储分配一样的 。
所以在利用二维数组作为参数传递时 , 必须指定二维数组的列数,否则函数无法勾画出二维数组的组织形式 。只有有了列长度,通过下标a[i][j]时才能得到正确的下标地址,即:
我们改一下上面的额foo函数定义:
编译运行:
这下就正常了 。
参数如上所列 。
我们看到,函数的参数声明改成了:
这个声明的含义是:
不过此时还是需要指定二维数组的列长度,不然函数内部还是无法使用二维下标去访问数组:
编译:
原因同前面方法1一致,如果要访问二维数组 , 必须指定列的长度 , 否则无法计算出该元素的地址 , a[i][j]=a [ (i-1)*COLNUM + j ] , 如果没有COLNUM,那么这个地址无法计算出来 。从形参的声明来说,a就是一个指针,指向一维数组的指针,而不是一个二维数组 。
这里要注意的是指针的指针,和二维数组的差异C语言函数数组传递原理;二维数组的地址是连续的,所有成员按顺序排序;而指针的指针只要求指针地址连续 , 而不要求指针的指针地址连续 。
然后作为实参传递时,也不能直接使用a传递,因为类型不匹配 , 必须定义新的变量p,然后把a的值赋给p , 再传递给foo函数 。
C语言中 , 数组做函数参数如何才能按值传递?传数组给一个函数,数组类型自动转换为指针类型,因而传的实际是地址 。
void func(int array[10])
void func(int array[])
void func(int *array)
所以以上三种函数声明完全等同 。
实际情况是,数组做参数,完全无法按值传递 。这是由C/C++函数的实现机制决定的 。
下一个问题是:为什么偏要按值传递呢?当要在一个函数内使用一个数组时,传一个指针进去不就行了?只要能访问到我们所要的数据并对其进行操作,何苦钻牛角尖 。
C语言函数数组传递原理的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于c语言数组在函数中的传递、C语言函数数组传递原理的信息别忘了在本站进行查找喔 。

推荐阅读