c – 为什么在这个例子中有1 == *(a 1)?

前端之家收集整理的这篇文章主要介绍了c – 为什么在这个例子中有1 == *(a 1)?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
#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) );

猜你在找的C&C++相关文章