下面的代码为什么打印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:56 编辑
传入 func() 的是二维数组 a 的首地址,内容依序为: 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12,相当于连续存储的一维数组。
在 func() 中,b 被声明为末维为 3 的二维数组,所以,b 相当于 b = b,恰好就应该是 9 jackz007 发表于 2019-2-26 23:32
传入 func() 的是二维数组 a 的首地址,内容依序为: 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , ...
传入func()的二维数组 a 的首地址 是a的地址,还是a的地址,这个地址的跨度是?
2316829671 发表于 2019-2-27 10:20
传入func()的二维数组 a 的首地址 是a的地址,还是a的地址,这个地址的跨度是?
传入 func() 的是数组 a 的首地址,也就是数组中第一个元素的地址。如果把 a 看成是一维数组,那么便是 a,如果把 a 看成二维数组,便是 a,其实,无论是一维还是多维数组,在计算机内存中都是按照一维数组的方式依序线性存储的,实质上都可以看做一维数组。
在本例中,虽然数组 a 被定义为末维为 4 的二维数组,而在 func() 中,又被解读为末维为 3 的二维数组,二者虽然有差异,但是,如果分别把两个定义按照一维数组解读,很容易定位目标元素。 我觉得c++这个方面比较清楚,因为这个在c++里面是个错误代码。
那从c的角度看吧,
传入的a是二维数组的首地址,
而在func()里面的形参 b[] 却是一个指向数组(内含三个int元素)的指针,
就按照 b 的形式变成了:{{1,2,3},{4,5,6},{7,8,9},{10,11,12}}
大概就是这样
页:
[1]