重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
在学习C语言的过程中遇到数组作为参数传递的问题
创新互联致力于互联网网站建设与网站营销,提供成都网站制作、网站建设、外贸网站建设、网站开发、seo优化、网站排名、互联网营销、微信平台小程序开发、公众号商城、等建站开发,创新互联网站建设策划专家,为不同类型的客户提供良好的互联网应用定制解决方案,帮助客户在新的全球化互联网环境中保持优势。
一维数组:
这样我们可以很顺利的在test去遍历这个数组a,当然我们还可能传递指针:
一般来数参数的传递是值传递,也就是说实参传给形参,形参发生改变时实参并不会改变,(单向)但是数组在传递的时候是地址传递,只要形参发生了变化,实参也会发生变化(双向)。
这样传递数组就会发现一个问题,我没有办法获取到数组的长度。获取数组的长度我们一般用:
我们会发现n的值一直是2!为什么会这样呢!?
因为,a是函数参数,到了本函数中,a只是一个指针(地址,系统在本函数运行时,是不知道a所表示的地址有多大的数据存储空间,这里只是告诉函数:一个数据空间首地址),所以,sizoef(a)的结果是指针变量a占内存的大小,一般在64位机上是8个字节。int类型是4个字节,所以,结果永远是2,因此,我们要向获取数组长度要怎么办呢?
我可以在初始化数组的地方获取到数组的长度,作为参数传递过来:
这样做我们可以获取到数组的长度。
二维数组:
二维数组作为参数传递是后我们不可以像以为数组那样直接,如:
会发现编译都编译不通过,报“[Error] declaration of 'a' as multidimensional array must have bounds for all dimensions except the first”这个错,意思是多维数组的定义必须有一个除第一个之外的所有维度的边界,比如:
这样就OK了,但是我们是动态分配的数组不知道这个维度是多少的时候怎么办?这时候我们可以用指针当做一维数组来操作:
这样我们发现不能更灵活的去定位到某一行某一列,这样我们需要手工改变寻址方式:
二维数组作为函数参数,实参可以直接使用二维数组名,在被调用函数中对形参数组定义可以指定所有维数的大小,也可以省略第一维的大小说明,如:
它们是合法且等价,也可以使用如下形式:
但不能省略第二维的大小,如下面的定义是不合法的,编译时会出错:
因为从实参传递来的是数组的起始地址,如果在形参中不说明列数,编译器将无法定位元素的的位置。
将数组传递给函数后,数组就会退化为指针
void fun(int x, int pp[], int *n)
void fun(int x, int *pp, int *n)
// 这两种写法是等价的
pp[j++]=j; // 这句写错了
// 要保存到pp里的是能整除的整数,而不是计数器j,如果这么写,那么pp的值肯定是{0,1,2,3,4,5,...}
// 应该改成
pp[j++] = l; // L才是被整除的整数,要保存的是这个
*n=j; // n作为一个指针,负责传出得到的数字的数量,j是计数器,当所有的计算完毕后,j的值自然是这些数字的数量
这道题刚刚做到了,正确答案是c
牛客网大佬给出的解答,A,必须在主调函数中说明此数组的大小,不一定例如传递一个char类型的字符串,就不需要。所以A是错的
数组作为参数是按地址传递的
数组名就是数组的首地址。因此在数组名作函数参数时所进行的传送只是地址的传送, 也就是说把实参数组的首地址赋予形参数组名。形参数组名取得该首地址之后,也就等于有了实在的数组。实际上是形参数组和实参数组为同一数组,共同拥有一段内存空间。
调用时把【】去掉,表示掉用这个数组的所有元素,数组的名称表示数组第一个元素的地址。
数组的定义可以写成:
int
table[]={1,2,3,}
或者table[3],不能写成table[],因为系统在定义数组时就给数组分配了地址,table[]没有确定元素的个数,不能分配地址空间。
但是作为形参,可以这样写,void
tab(int
table[])
,不知道为什么,呵呵