若有定义int(*p)[3]; 则定义了一个名为p的指针变量 它可以指向每行有三个整数元素的二维数组

请问如何理解这句话和此定义 为什么是二维数组?

楼主你好!
首先(*p)[3]是一个指针数组,意思就是p这个指针是指向一个含有3个元素的数组的,那么p指针每一次加1就相当于把p中存的地址加6(前提是int类型占2个字节,在VC中是占4个字节)。
举个例子:
int a[3][3];
int(*p)[3];
p=a; //也就是把数组a的首地址存放到p中

那么p[1]就是a[1][0]的地址,p[1][0]就等于a[1][0],而p[1][2]就等于a[1][2];
这就说明了为什么是二维数组了
温馨提示:内容为网友见解,仅供参考
第1个回答  2012-03-15
问题1:首先,这里只是定义了一个指针型变量,这个p是一个指向长度为3的整型数组得指针,那么这个数组最大有多少行,取决于先面这个赋值(int array[n][3];p=a;),在这里虽然n有多大,那么p就有多少行,它能不停得加下去,直到n-1;
问题2:这个是编译系统的问题了,就像我们下得所有C语言代码,计算机是不能识别的,因为计算机只能识别二进制,那么如何能让计算机识别大家写得C语言代码,就需要编译,这里就是语法规则,编译系统会按照我们定义的类型和数组范围进行地址上得变化,比如这个例子,首先用的是整型,加入编译系统认为整型是2个字节,这里数组长度是3,那么p+1相当于地址加了2*3=6,如果编译系统认为整型是4个字节(visual C++ 6.0就是默认整型4个字节 ),那么p+1相当于地址加了4*3=12,说到底,这个是编译系统需要考虑得问题,读者不用太过于追究,除非你准备开发编译器。希望我的回答你还满意。
第2个回答  2011-03-20
p 是一个指向有三个整数的数组的指针类型变量。 p+1 就是指向下一个三位数组。 这样下去,不就相当于是二维数组了。追问

二维数组不应该是p[3][3]这种类型的吗

第3个回答  2011-03-20
*p 即代表了这是一个整形数组的首地址,【3】则说明p中每个元素又包含3个元素。
第4个回答  2017-11-20
首先(*p)[3]是一个指针数组,意思就是p这个指针是指向一个含有3个元素的数组的,那么p指针每一次加1就相当于把p中存的地址加6(前提是int类型占2个字节,在VC中是占4个字节)。
举个例子:
int a[3][3];
int(*p)[3];
p=a; //也就是把数组a的首地址存放到p中
那么p[1]就是a[1][0]的地址,p[1][0]就等于a[1][0],而p[1][2]就等于a[1][2];
这就说明了为什么是二维数组了
相似回答