数组元素 c++ 的地址
Address of array elements c++
可能的重复项:
C++中的指针算术使用大小(类型)增量而不是字节增量?
试图找到答案,但无法找到。我有以下 c++ 代码:
struct A {
uint16_t a;
uint16_t b;
uint16_t c;
}
int main() {
uint16_t * B = new uint16_t[5000];
for (int i=0;i<5000;i++)
B[i] = i;
uint16_t * D = &B[500]+sizeof(A);
}
问题是:为什么在此之后 *D=512?当我调试 sizeof(A) = 6 时,它应该是。然而,我在 B[500] 的内存地址中添加了 A 的大小,它增加了 12 而不是 6。我正在使用内存地址仍然有一个乘法,我无法弄清楚为什么会这样。
请指教。
谢谢!
如果sizeof(A)
确实是 6,这是一个编译器错误。
&B[500] + 6 == &B[506]
因此*D
应该是506。这是当我编译的时候
#include <iostream>
#include <cstdint>
struct A {
uint16_t a;
uint16_t b;
uint16_t c;
};
int main() {
uint16_t * B = new uint16_t[5000];
for (int i=0;i<5000;i++)
B[i] = i;
uint16_t * D = &B[500]+sizeof(A);
std::cout << (*D) << std::endl;
return 0;
}
使用 g++-4.7.1 或 clang++-3.1。
相关文章:
- 将数组的地址分配给变量并删除
- 空基优化子对象的地址
- C++ 指针的内存地址和指向数组的内存地址如何相同?
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 如何在c++程序中找到函数的地址
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- 被解释为低级别const的const对象的地址
- 将地址分配给本地指针后,公共对象的变量将消失
- 为什么我在leetcode上收到AddressSanitizer:地址0x602000000058上的堆缓冲区溢出错误
- 内联程序集printf将整数解释为地址
- 为什么指针不写入类的地址?
- 如何在C++中获取该对象的类声明中对象的地址?
- 通过按地址访问变量
- 当一个新对象被分配到它的地址时,对象是否必须被销毁
- 函数名是c中该函数的第一条指令的地址吗
- Visual Studio(或任何其他工具)能否将地址解释为调用堆栈(boost上下文)的开头
- ReadProcessMemory() 不适用于像 0x2840C6C68D8 这样的长地址
- CUDA:统一内存和指针地址的更改
- 当我们从/tp地址中添加/减去一个整数时会发生什么
- 如何使用 Boost Asio 在 Android 上获取我的本地 udp IP 地址?