为什么在这个例子中 a+1 == *(a+1)
Why does a+1 == *(a+1) in this example?
#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
为什么a+1 == *(a+1)
?
a + 1
是a
中第二个元素的地址,也可以写成&a[1]
(根据定义相当于&*(a + 1)
(。
*(a + 1)
是一个引用第二个数组的左值。根据定义,它等同于a[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) );
相关文章:
- 为什么"do while"循环不断退出,即使条件计算结果为 false?
- 为什么在全局范围内使用"extern int a"似乎不行?
- 为什么在popback()操作之后,它仍然打印完整的矢量
- 为什么随机数生成器不在void函数中随机化数字,而在main函数中随机化
- 为什么两个不同的未命名名称空间可以共存于一个cpp文件中
- 为什么会发生堆损坏
- 为什么使用 "this" 指针调用派生成员函数?
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 为什么比较运算符如此快速
- 为什么 Serial.println(<char[]>);返回随机字符?
- 为什么这个运算符<重载函数对 STL 算法不可见?
- 为什么不;名字在地图上是按顺序排列的吗
- 我的字符计数代码计算错误.为什么
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 为什么我的C#代码在调用回C++COM直到Task时会暂停.等待/线程.加入
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 为什么野牛仍在使用"int yylex(void)",却找不到"int yylex(YYS
- 为什么 std::unique 不调用 std::sort?
- 既然存在危险,为什么项目要使用-I include开关
- 为什么在运行时没有向我们提供有关分段错误的更多信息?