一维数组:
这样我们可以很顺利的在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了,但是我们是动态分配的数组不知道这个维度是多少的时候怎么办?这时候我们可以用指针当做一维数组来操作:
这样我们发现不能更灵活的去定位到某一行某一列,这样我们需要手工改变寻址方式:
一种是把数组元素(下标变量)作为实参使用;
一种是把数组名作为函数的形参和实参使用。
数组元素作为函数实参使用与普通变量是完全相同的,在发生函数调用时,把作为实参的数组元素的值传给形参,只是“拷贝”实参中的变量的值,传送给形参,实现单向的值传送
用数组名作为函数参数与用数组元素作实参有几点不同:
1)用数组元素作函数参数不要求形参也必须是数组,但是用数组名作函数参数时,则要求形参和相对应的实参都是类型相同的数组。
2)在 C 语言中,数组名除作为变量的标识符之外,数组名还代表了该数组在内存中的起始地址,当数组名作函数参数时,实参与形参之间不是“值传递”,而是“地址传递”,实参数组名将该数组的其实地址传给形参数组,两个数组共享一段内存单元,编译系统不再为形参数组分配存储单元。
3)在变量做函数参数时,所进行的值传递是单向的。即只能从实参传向形参,不能从形参传回实参。
1)形参数组和实参数组类型必须一致,否则出错。
2)在函数形参表中,允许不给出形参数组的长度,或用一个变量来表示数组元素的个数。
或写为:
n 的值由主调函数的实参进行传递。
所有的地址都占8个字节。
3)形参数组和实参数组长度可以不相同,因为在调用时,只传递首地址而不检查形参数组的长度。
#include<stdio.h>#include<string.h>
void swap ( char a[] , char b[] )
{
char temp[20]
strcpy(temp,a)
strcpy(a,b)
strcpy(b,temp)
}
void main()
{
char s1[20],s2[20],s3[20]
printf("请输入三个字符串(不超过20个字符)\n")
scanf("%s %s %s",s1,s2,s3)
if( strcmp(s1,s2)>0 ) swap(s1,s2)
if( strcmp(s1,s3)>0 ) swap(s1,s3)
if( strcmp(s2,s3)>0 ) swap(s2,s3)
printf("排序后:\n%s\n%s\n%s\n",s1,s2,s3)
getch()
}
只是改了swap函数。