数组指针与指针数组
1 数组指针
数组指针是一个指向数组的指针,本质是一个指针,只不过它指向的是一个数组。一个指向有10个元素整型数组的指针定义为:
int(*p)[10]; //(其中[]表示指向数组,10表示数组大小)。由于[]的优先级高于*,所以必须加上()。
二维数组的数组名是一个数组指针。
int(*p)[10];
int a[4][10];
p = a; // a的类型是int(*)[10];
一维数组的数组名的地址也是一个数组指针。
int a[10];
int (*p)[10] = &a; // 此处是&a,不是a,a的类型是int*,&a的类型是int(*)[10]
例题1:
int a[] = { 0, 2, 4, 6, 8 };
int *ptr = (int *)(&a + 1);
cout << *(ptr - 1) << endl; // 输出:8
数组名本来就是指针,加上&就变成数组指针,&a指向一个大小为20 (sizeof(a)=20) 的数组,&a+1指向数组a最后元素的下一个元素,而(int*)将(&a+1)强制转换为一个指向int型对象的指针,故p-1指向数组a的最后一个元素8。
2 指针数组
指针数组是一个存放指针的数组,本质是一个数组,只不过数组里存放的是指针。一个存放着10个指针的数组定义为:int *a[10];指针数组的数组名是一个二级指针。
char *a[10] = { "work", "at", "Alibaba" }; //数组a里面存放的是10个指针
char **p1 = a; // 指针数组的数组名是一个二级指针
char **p2 = a;
p1++;
cout << *p1 << endl; // 输出:at
(*p2)++; // *p2是指向字符串“work”的指针,再++则指向"work"的第二个字符,故输出:ork
cout << *p2 << endl; // 输出:ork