@zhutoulwz
2017-04-19T15:48:49.000000Z
字数 748
阅读 1841
指针数组:首先它是一个数组,数组的元素都是指针,数组占多少个字节由数组本身决定。它是“储存指针的数组”的简称。
数组指针:首先它是一个指针,它指向一个数组。在32 位系统下永远是占4 个字节,至于它指向的数组占多少字节,不知道。它是“指向数组的指针”的简称。
下面到底哪个是数组指针,哪个是指针数组呢:
int *p1[10];
int (*p2)[10];
“[]”的优先级比“”要高。p1 先与“[]”结合,构成一个数组的定义,数组名为p1,int *修饰的是数组的内容,即数组的每个元素。那现在我们清楚,这是一个数组,其包含10 个指向int 类型数据的指针,即指针数组。至于p2 就更好理解了,在这里“()”的优先级比“[]”高,“”号和p2 构成一个指针的定义,指针变量名为p2,int 修饰的是数组的内容,即数组的每个元素。数组在这里并没有名字,是个匿名数组。那现在我们清楚p2 是一个指针,它指向一个包含10 个int 类型数据的数组,即数组指针。我们可以借助下面的图加深理解:
int main()
{
int (*p)[5]; // p是指针,指向一个int[5]的数组
cout << sizeof(p) << endl;
int arr[5];
arr[0] = 1;
arr[1] = 2;
p = &arr;
cout << (*p)[1] << endl;
int *p1[5]; // 指针数组,本质是一个数组,数组的每个元素都是一个int*指针,是“储存指针的数组”
cout << sizeof(p1) << endl;
p1[0] = new int[5];
p1[1] = new int[10];
int a = 1;
p1[2] = &a;
cout << *(p1[2]) << endl;
}