基础知识
如果给定一个数组int a[4]。那么a是数组的首地址,它可以被当成一个int 的指针来用。
那么假如给定一个二维数组int a【3】【4】,那么a也可以被当成指针来使用,只不过类型是指向存储四个int型数据数组的指针。即int ()[4]。
int (*p)[4]
由于()的优先级高于[]的优先级,因此p先和()结合,表示p是一个指针,那么它指向的类型是什么呢?就是int [4],即一个含有四个int型数据的数组。(函数指针也可以这么理解)那么对其初始化的话也只能使用一个int(*)[4]类型的指针。例如:
void test()
{
int a[2][4]{1,2,3,4,5,6};
int (*p)[4]=a;
cout<<(*p)[0]<<endl;
cout<<(*p)[1]<<endl;
}
打印的结果就是1,2。
那么数组指针p加1后跳跃的长度是多少呢?
不难想出其跳跃的长度是指向的数组的长度,即4。
void test()
{
int a[2][4]{1,2,3,4,5,6};
int (*p)[4]=a;
cout<<(*(p+1))[0]<<endl;
}
打印结果就是5。
int *p[4]
由于[]的优先级高于* ,因此p首先和[]结合,表示p是一个数组,其次与*结合,表示其存储的类型是int *的指针。例如:
void test()
{
int a = 0;
int b = 1;
int c = 2;
int d = 3;
int *p[4];
p[0] = &a;
p[1] = &b;
p[2] = &c;
p[3] = &d;
for (int i = 0; i < 4; i++)
{
cout<<*p[i]<<endl;
}
}
打印的结果就是0,1,2,3。
那么指向指针数组的指针p加1后跳跃的长度是多少呢
void test()
{
int a = 0;
int b = 1;
int c = 2;
int d = 3;
int *p[4];
p[0] = &a;
p[1] = &b;
p[2] = &c;
p[3] = &d;
cout<<*(p+1)[2]<<endl;
}
打印结果为3。可以看出来跳跃的长度为1。
可以这样理解:p可以当成指针数组int *p[4]的首地址,它指向p[0]。将p+1后它就指向了p[1],可以把p[1],p[2],p[3]看成新数组的三个元素,这个新数组的首地址就是p+1。因此(p+1)[2]就是这个新数组的第三个元素也就是p[3],对其解引用后就是d的值,即3。
总结
这两个之间的区别对新手来说有点难以理解,希望这篇博客能帮助到初学者。