列指针
列指针简而言之就是指向数组中的一个元素,例如:在数组a[2][3]中
int a[2][3]={{1,2,3},{4,5,6}};
行指针指向的是确定元素a[0][0],a[1][2]或者其他元素,定义的时候,我们让指针指向数组a的首行地址即可
int *p=a[0];
若要对数组中的元素进行访问
for(i=0;i<2;i++)
{
for(j=0;j<3;j++)
{
printf("a[%d][%d]:%d\n",i,j,*(p+3*i+j));
}
}
行指针(数组指针)
行指针指向的是数组中每一行的地址,意味着我们如果要访问数组中的每行首地址元素,需要对我们的指针进行两次解引用操作,例如:
int (*p)[3] = a //首先对行指针初始化,需要注意要加括号,不然就变成指针数组
/*先来看看首行地址*/
printf("*p:%d\n",*p);
/*接下来读取数组中第一行行首元素*/
printf("**p:%d\n",**p);
输出结果如下:
如果需要对数组中每个元素进行访问(行指针向列指针的转换),即先取出每行首地址后,再加上每一列相对于此行首元素的偏移量*(*(p+i)+j) 。
*(p+i)相当于每一行的地址,来看看代码。
for(i=0;i<2;i++)
{
printf("a[%d]:%d\n",i,*(p+i));
}
结果如下:
对每一个元素进行打印:
for(i=0;i<2;i++)
{
for(j=0;j<3;j++)
{
printf("a[%d][%d]:%d\n",i,j,*(*(p+i)+j));
}
}
打印结果如下:
最后,特别提一下指针数组
int *p[3];
指针数组相当于一个数组,其中存放的都是指针变量,我们将a[2][3]的每一行首地址存入这个数组,再通过解引用操作得到每一行的首元素。
for(i=0;i<2;i++)
{
p[i]=a[i];
printf("*p[%d]:%d",i,*p[i]);
}
打印的结果:
若要访问所有元素:
for(i=0;i<2;i++)
{
p[i]=a[i];
for(j=0;j<3;j++)
{
printf("a[%d][%d]:%d\n",i,j,*(p[i]+j));
}
}
打印的结果: