#include <iostream> int main() { int a[3][3] = {{22,33,44},{55,66,77},{88,99,100}}; std::cout << a[1] << '\n' << a + 1 << '\n' << *(a + 1); }
0x0013FF68 0x0013FF68 0x0013FF68
为什么1 == *(a 1)?
解决方法@H_301_10@
a 1是a中第二个元素的地址,也可以写成& a [1](根据定义等同于& *(a 1)).
*(a 1)是指第二个数组的左值.这相当于[1]的定义.
就像任何其他阵列指针衰减一样,这个左值衰减到指向其引用的数组的第一个元素的指针,即它衰减到& a [1] [0].但这相当于该数组对象本身的地址.所以这个值与& a [1]的值是一样的…这正是我们如何定义上述表达式a 1的值.
请注意,数组被衰减为指针,因为第二次插入的最佳匹配为operator<<(void const*)
.请考虑
int (*p1)[3] = a + 1;
int (&p2)[3] = *(a + 1); // We could also have written *p1
int* p3 = p2; // The array-to-pointer decay
assert( static_cast<void*>(p1) == static_cast<void*>(p3) );
*(a 1)是指第二个数组的左值.这相当于[1]的定义.
就像任何其他阵列指针衰减一样,这个左值衰减到指向其引用的数组的第一个元素的指针,即它衰减到& a [1] [0].但这相当于该数组对象本身的地址.所以这个值与& a [1]的值是一样的…这正是我们如何定义上述表达式a 1的值.
请注意,数组被衰减为指针,因为第二次插入的最佳匹配为operator<<(void const*)
.请考虑
int (*p1)[3] = a + 1; int (&p2)[3] = *(a + 1); // We could also have written *p1 int* p3 = p2; // The array-to-pointer decay assert( static_cast<void*>(p1) == static_cast<void*>(p3) );