二维数组指针怎么使用?极悦小编来告诉大家。
int a[5]={1,2,3,4,5};
int *p=(int *)(&a+1);
int *q=(int *)&a;
printf("%p,%p,%p",a,p,q+1);
本身a作为一个地址,p作为指向a的地址,相当于一个二维指针, 一个二维指针加一相当于移动了一行,所以这里是移动了5*4个字节,而对于q+1的情况,说明移动了4个字节。
注意:行指针和列指针的定义方式就不一样
对于指向二维数组的指针变量p,可以有两种:
一种是指向数组元素的列指针
一种是指向行的行指针,这时,p不是指向一个具体的数组元素,而是指向一个包含m个元素的一维数组。这里对行指针特殊说明一下;
行指针的定义形式为:类型标识符 (*指针变量名)[长度];
例如: int a[3][4],(*p)[4]=a; //这里也可以写为int a[3][4],(*p)[4]=&a[0];
其中p,p+1,p+2和a,a+1,a+2都是第i行的首地址。
使用指针变量访问二维数组的任意一个元素的方法
(1)使用列指针:定义一个列指针p,让它指向二维数组的第0个元素
int a[3][4];
int *p
p=&a[0][0]; //因为a[0]是第0行的数组名,所以p=&a[0][0]相当于p=a[0],因为a[i][j]前面共有i*4+j个元素,该二维数组的任意i行j列元素可表示为*(p+i*4+j)(使用列指针表示每个元素的方式)
(2)使用行指针:定义一个行指针p,让它指向二维数组的第0行
int a[3][4];
int (*p)[4];
p=a; //也可以为p=&a[0];
其中* ( *(p+i)+j)表示任意一个i行j列的元素。
根据行指针和列指针都可以找到数组中的每一个元素,但是方式不一样。
你适合学Java吗?4大专业测评方法
代码逻辑 吸收能力 技术学习能力 综合素质
先测评确定适合在学习