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

现在提问。有人回答说,
“p 是一个指向有三个整数的数组的指针类型变量。 p+1 就是指向下一个三位数组。 这样下去,不就相当于是二维数组了。”
还有人说,“p指针每一次加1就相当于把p中存的地址加6(前提是int类型占2个字节,在VC中是占4个字节)”

提问,
1.这个数组的最大能有多少行?p不停的加下去吗?
2.“p指针每一次加1就相当于把p中存的地址加6” 这能说明什么,为啥地址变化了。自动的就认为还是三个整数元素的数组?到底发生了什么变化?
没有行数规定。比如
void setT(int i ,double (*T)[5])
{
T[0][i]=1;
T[1][i]=2;
T[2][i]=3;
}
如此,并没有写要多少行啊

楼主你好!
首先(*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个回答  2012-03-15
归纳起来就是int型或是float型都有系统规定的大小。不能超过这个规定的大小,否则就会溢出。

其次,电脑使用二进制来完成它的功能的,但是通过汇编语言,面向对象等的语言,转换为二进制,就能被电脑识别。但是这个一般是要通过一些软件来完成的,如c++编译器visual c++6.0,java编译器myeclipse
第3个回答  2012-03-15
执行p+1就行了
第4个回答  2012-03-15
顶楼上!
相似回答