二维数组传参问题

前言:之前一直知道二维数组名是指针的指针,是一个二级指针,总想着在函数定义时把它定义为一个二级指针,可是一次也没成功过,直至这次实训遇到了这个二维数组传参问题,求助了一个同学才得以解决。本文解决 的问题是怎么样将二维数组作为一个参数传递到函数中。
步骤
我们都知道在函数调用前需要先声明和实现。对于一个整型二维数组。其实在函数签名中写形参定义:int a[3][3],代表的就是这个函数中有一个3*3的整型数组。和函数调用时传进去的a[3][3]含义完全不同。这个a[3][3]代表的是一个元素,方括号内容是其索引下标。知道了这一点不同就好办了。因此如果你想让一个二维数组作为函数参数时,不需要再考虑什么二级指针什么的,只需要在函数签名里向定义一个二维数组一样写上你所需要数组的类型和大小,与此同时在函数调用的实参中把该函数名传进去即可。
由于实参放进去的是一个数组名(二级指针即地址),因此从该种方式的函数传参属于地址传参。函数调用是可以改变传进去的实参的。
例子证明

#include
void Print(int a[3][3]){
	for(int i=0;i<3;i++){
		for(int j=0;j<3;j++)
			printf("%-5d",a[i][j]);
		printf("\n");
		
	}
}
void Change(int a[3][3]){
	for(int i=0;i<3;i++){
		for(int j=0;j<3;j++)
		 	a[i][j]=1;
	}
}
int main(){
	int a[3][3]={0};
	Print(a);
	Change(a);
	Print(a);
	return 0;
	
}

上述例子验证了这样传递二维数组的正确性和传址传递的正确性。

你可能感兴趣的:(C语言,c语言)