迪士尼源码搭建下载【
指针数组 : 存放指针的数组
其定义抽象为:指向变量的类型 * 数组名称 [数组长度]。
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则解得第一行的第二个元素地址。
---------------------
版权声明:本文为CSDN博主「太上忘情_」的原创文章,遵循CC 4.0 by-sa版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_38260691/article/details/98991461