在内存地址中计算 2 补码中的符号位
Counting Sign Bit in 2's Complement in Memory Address
例如,在 c++ 中,如果变量的内存地址显示为 0XFFF,我不确定它是 2047 还是 4095(包括"符号位")。 0xFFF二进制为 1111 1111 1111。我最近了解了"符号位",它只是指示数字是正数还是负数。我的另一个猜测是,转换为 2 的补码正数后,它将是 0000 0000 0001。所以我的问题是:0XFFF的内存地址是否表明它是 4095 还是 2047?或者,也许是 1?
0xFFF
可以是其中之一。 在十六进制中,它只是位 - 其余的都取决于你如何解释它。它还取决于我们正在谈论的数据类型的宽度。
假设您没有使用 12 位数据类型,则您显示的特定值始终为 4095。
现在,如果我们确定整数的宽度,并选择不同的值,事情会变得更加有趣。 以 16 位值0xFFFF为例:
- 解释为无符号整数(即
uint16_t
),它是 65535。 - 作为有符号整数(即
int16_t
),它是 -1。
内存地址通常被视为无符号值,因此 two 的补码在这方面确实没有发挥作用。
对于有符号C++基元类型,标准不在乎。它是否存储为二进制补码取决于 CPU 架构,对于 x86 和大多数架构,由于硬件实现的便利性,使用 2 的补码。
相关文章:
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 有符号的int和int-有没有一种方法可以在C++中区分它们
- 将无符号char*转换为std::istream*C++
- 如何在C++中将一个无符号的 int 转换为两个无符号的短裤?
- vscode g++链路故障:体系结构x86_64的未定义符号
- 从矢量<无符号字符>转换为字符* 包括垃圾数据
- 如何理解将半精度指针转换为无符号长指针和相关的内存对齐
- Visual studio代码重构似乎不起作用(例如,重命名符号-f2)
- 使用gcc从静态链接的文件中查找可选符号
- C++中无符号字符溢出
- 使用无符号字符数组有效存储内存
- C++:Application.cpp中抛出了未解析的外部符号(解决方案在问题的末尾,供未来的读者参考)
- VC++本机单元测试,找不到调试符号
- 为什么我必须在C++中添加一个赋值符号来声明一个数组
- 检查TCHAR数组输入是否为带符号整数C++
- 用符号版本替换对函数的所有调用
- 有符号双字到无二进制补码的无符号双字
- 在内存地址中计算 2 补码中的符号位
- 为什么 -INT_MIN = INT_MIN 在有符号的 2 补码表示中?
- c++无符号整型的位补码返回负值