2316829671 发表于 2019-2-26 23:04:28

下面的代码为什么打印9

本帖最后由 2316829671 于 2019-2-26 23:06 编辑

#include <stdio.h>

void func(int b[]);

void func(int b[])
{
      printf("%d\n", b);
}

int main(void)
{
      int a = {
                {1, 2, 3, 4},
                {5, 6, 7, 8},
                {9, 10, 11, 12}
      };

      func(a);

      return 0;
}

传向func函数中的参数到底是什么

jackz007 发表于 2019-2-26 23:32:43

本帖最后由 jackz007 于 2019-2-26 23:56 编辑

      传入 func() 的是二维数组 a 的首地址,内容依序为: 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12,相当于连续存储的一维数组。

      在 func() 中,b 被声明为末维为 3 的二维数组,所以,b 相当于 b = b,恰好就应该是 9

2316829671 发表于 2019-2-27 10:20:37

jackz007 发表于 2019-2-26 23:32
传入 func() 的是二维数组 a 的首地址,内容依序为: 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , ...

传入func()的二维数组 a 的首地址 是a的地址,还是a的地址,这个地址的跨度是?

jackz007 发表于 2019-2-27 10:43:33

2316829671 发表于 2019-2-27 10:20
传入func()的二维数组 a 的首地址 是a的地址,还是a的地址,这个地址的跨度是?

      传入 func() 的是数组 a 的首地址,也就是数组中第一个元素的地址。如果把 a 看成是一维数组,那么便是 a,如果把 a 看成二维数组,便是 a,其实,无论是一维还是多维数组,在计算机内存中都是按照一维数组的方式依序线性存储的,实质上都可以看做一维数组。
      在本例中,虽然数组 a 被定义为末维为 4 的二维数组,而在 func() 中,又被解读为末维为 3 的二维数组,二者虽然有差异,但是,如果分别把两个定义按照一维数组解读,很容易定位目标元素。

发撒旦法 发表于 2019-2-27 11:38:42

我觉得c++这个方面比较清楚,因为这个在c++里面是个错误代码。
那从c的角度看吧,
传入的a是二维数组的首地址,
而在func()里面的形参 b[] 却是一个指向数组(内含三个int元素)的指针,
就按照 b 的形式变成了:{{1,2,3},{4,5,6},{7,8,9},{10,11,12}}
大概就是这样
页: [1]
查看完整版本: 下面的代码为什么打印9