C++指针与数组和指针强制转换
C++ pointer vs array and pointer casting
我正在尝试以下代码:
unsigned long * foo = (unsigned long *) 0x200000;
因此,据我了解,foo 指向未签名的长0x200000。现在,如果我尝试,
std::cout<<foo[0];
我认为这应该打印值0x200000
(可能是十进制)。因为,foo[0] = *(foo + 0) = 0x200000
.但是,它实际上打印0
.
我在这里缺少什么?
你误会了,
unsigned long * foo = (unsigned long *) 0x200000;
将0x200000解释为unsigned long
的地址。由于该地址极不可能是您可以在程序中合法访问的unsigned long
的地址,
std::cout<<foo[0];
几乎可以肯定是未定义的行为,并可能导致段错误。但是,在您的情况下,访问该内存位置不会导致段错误,并且那里的位被解释并打印为unsigned long
,它们恰好都是 0。
type * pointerName = addressItPointsTo;
pointerName[0]
与 *pointerName
相同,表示取消引用指针并获取它指向的地址处的值。它恰好是 0,但它通常会导致分段错误。
相关文章:
- 正在将指针转换为范围
- 如何理解将半精度指针转换为无符号长指针和相关的内存对齐
- C++:Lambda 函数指针转换的用例是什么?
- 如何将 int 指针转换为浮点指针
- 为什么在将 void 指针转换为整数指针时出现分段错误
- 将(N 个字节)无符号字符指针转换为浮点数和双 C++
- 我们可以在不知道其真实类型的情况下将基类指针转换为派生类指针吗?
- C++中数组大小未知的指针转换
- Antlr cpp 运行时 任何错误的指针转换?
- std::flush可以用于将对象指针转换为其封闭数组指针吗
- C 指针转换会导致内存访问冲突
- 模板类实例化中的指针转换无效
- 函数调用歧义(用户定义的转换和 Derived2Base 指针转换)
- 如何将 void(*)() 类型的指针转换为 void*
- 数组到指针转换期间的临时具体化
- 直接为浮点变量分配十六进制整数与通过指针转换分配之间的区别
- 将基类指针转换为派生的类指针
- 应对 std::字符串中的 std::<char>指针转换后的向量
- 在编译时将函数指针转换为 std::uintptr_t
- 将基类指针转换为未知派生类指针