C语言二维数组怎么写好
C语言二维数组怎么写好
有同学在面对二维数组的时候,常常会犯浑。尤其是使用函数传参的时候,有老师讲到一维数组传参后就等价于一级指针,部分同学举一反三自学成才,想当然地认为二维数组传参后就等价于二级指针,这是错误的。
假如,有如下代码:
int a[2][3]; // 一个二维数组
function(a); // 将二维数组传参给一个函数
上述代码中,就是将一个二维数组传递给一个函数,那么这个函数怎么接受这个参数呢,答案是这样的:
void function(int a[2][3]) // 这是对的
{ }
void function(int (*a)[3]) // 这也是对的怎么定义二维数组c语言
{ }
千万别写成这样:
void function(int **a) // 这是错的'
{ }
究其原因,还是回到以前提过多次的数组与指针的结论:任何数组,都将被一律视为一个指向其首元素的指针。因此以下两行代码是等价的:
function(a);
function(&a[0]);
对于二维数组 int a[2][3] 而言,其首元素就是一个 int [3] ,因此&a[0]就是一个指向 int [3] 的指针,其类型当然是 int (*)[3] 了。这样再来看上述的function两种正确定义,就不难理解了。
【C语言二维数组怎么写好】

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。