微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

原文地址:https://www.jb51.cc/c/114963.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐