C语言(二维数组)

有同学在面对二维数组的时候,常常会犯浑。尤其是使用函数传参的时候,有老师讲到一维数组传参后就等价于一级指针,部分同学举一反三自学成才,想当然地认为二维数组传参后就等价于二级指针,这是错误的。

假如,有如下代码:

int a[2][3]; // 一个二维数组

function(a); // 将二维数组传参给一个函数

 

上述代码中,就是将一个二维数组传递给一个函数,那么这个函数怎么接受这个参数呢,答案是这样的:

void function(int a[2][3]) // 这是对的

}

void function(int (*a)[3]) // 这也是对的

}

 

千万别写成这样:

void function(int **a) // 这是错的

}

 

究其原因,还是回到以前提过多次的数组与指针的结论:任何数组,都将被一律视为一个指向其首元素的指针。因此以下两行代码是等价的:

function(a);

function(&a[0]);

 

对于二维数组 int a[2][3] 而言,其首元素就是一个 int [3] ,因此&a[0]就是一个指向 int [3] 的指针,其类型当然是 int (*)[3] 了。这样再来看上述的function两种正确定义,就不难理解了。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章