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)?

解决方法

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&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...