1. 指针数组 : 存放指针的数组
其定义抽象为:指向变量的类型 * 数组名称 [数组长度]。
int *p[2];
p[0] = NULL;
p[1] = NULL;
2. 数组指针 : 指向数组的指针
2.0 定义抽象:数组元素类型 (* 指针名称)[数组长度].
2.1 假设数组int a[2][2] = { {1,2},{3,4} };的首地址为0x11000000.则如下程序输出如下
int main()
{
int a[2][2] = { {1,2},{3,4} };
int(*p)[2] = &a[0];
cout << p << endl; //0x11000000
cout << p + 1 << endl; //0x11000008
cout << *p << endl; //0x11000000
cout << *(p + 1) << endl; //0x11000008
cout << *p + 1 << endl; //0x11000004
cout << **p << endl; //1
cout << **(p + 1) << endl; //3
cout << *(*p + 1) << endl; //2
}
2.2 总结
- 数组名始终等价于数组元素的首地址a == &a[0]
- 整个数组地址&a与数组首元素的地址&a[0]只是数值上相等,概念上完全不同。
第一次解引用得到某一行元素地址,第二次解引用得到具体数据,例如 *p 解得第一行元素首地址&a[0],**p则解得第一行第一个元素a[0][0],*(p+1)解得第二行元素首地址&a[1],而*p + 1则解得第一行的第二个元素地址。