数组与单个元素一样,也可以作为参数被函数调用,但其用法与单个元素调用存在不同。
对于单个元素调用,如不使用引用&或者指针,则在函数中对形参的操作不会反映到实参上,即实参不会发生改变,具体用法详见上一篇博客。
而对于数组调用,函数的形参看似是一个新的数组,但并未分配新的内存。因为数组的名字代表着数组的首地址。因此**在数组名作函数参数时所进行的传送只是地址的传送,也就是说把实参数组的首地址赋予形参数组名。**形参数组名取得该首地址之后,也就等于有了实在的数组。实际上是形参数组和实参数组为同一数组,共同拥有一段内存空间。
因此,形参数组是一个虚拟数组,其数组的地址指向了实参数组。如a[0]与b[0]都指向了同一个地址。在对形参数组进行操作时,实参数组的值也会相应的发生改变。
在函数调用数组的方法
1.对于一维数组:
void invert(int x[]){
//函数部分
}
int main(){
int a[10];
invert(a);
//主函数调用部分
}
注:
1.形参与实参的类型必须一样,如int对应int。
2.主函数调用invert函数时只需使用实参数组的名字,代表数组的地址。
3.形参数组可以不规定长度,但实参数组会规定长度。
另一种写法:
void invert(int x[10]){
//函数部分
}
int main(){
int a[10];
invert(a);
//主函数调用部分
}
可以规定好形参数组的长度。但由于形参数组是虚拟数组,其地址与实参数组的地址对应,故形参数组的长度其实并无太大意义。
void invert(int x[110]){
//函数部分
for(register int i=1;i<=100;i++){
x[i]=0;
}
}
int main(){
int a[10];
invert(a);
//主函数调用部分
}
若形参数组长度大于实参数组,则可能导致对形参数组的部分操作没有意义。如上文x[11]到x[100]没有意义。
若形参数组长度小于实参数组,可能导致部分实参数组未被操作。
但无论长度如何,关键都在于对形参数组操作的边界设置是否合理,如下文的代码并无问题。
void invert(int x[10]){
//函数部分
for(register int i=1;i<=100;i++){
x[i]=0;
}
}
int main(){
int a[100];
invert(a);
//主函数调用部分
}
2.对于多维数组:
在函数定义时对形参数组可以指定每一维的长度,也可省去第一维的长度。因此,以下写法都是合法的:
void invert(int sum[][110])
void invert(int sum[110][110])