c中对多维数组的支持并不是特别的完美,导致了许多的操作对于新手来说晦涩难懂。当然如果只是从语法本身出发考虑是很难理解为什么需要这么做的,但是从编译器的角度出发恰好可以获取意想不到的效果。这起决于编译也需要一定的条件才能判断,而这个条件往往就是为什么这样子可以的原因。
向函数传递数组,相信会记起一条规则“数组名会被改写成一个指针参数”。但是这个规则并不是递归定义的。也就是说在一维数组时,数组名确实被改写成了指针参数。但是数组的数组则会被改写成“数组的指针”,而不是“指针的指针”。
以下是一段示例程序,将帮助你理解:
#include "stdio.h"
int g_ia[10][20];
char *g_p_ca[]={"abcd","efg","hijk"};
//session 1:形参直接定义为 int l_ia[10][20]
//迫使函数只处理10行20列的int型数组
void array_func_exact_multiple_param(int l_ia[10][20]){
printf("l_ia[10][20]/n");
return ;
}
//session 2:形参定义为 int l_ia[][20]
//多维数组最主要的一维的长度(最左边一维)不必显示说明
//所有的函数都必须知道数组其他维的确切长度和数组的基地址。
//数组其他维的确切长度是为编译器提供一个确切的步长,以便计算地址
void array_func_exact_less_param(int l_ia[][20]){
printf("l_ia[][20]/n");
return ;
}