为什么掩盖一个负数会产生一个正数?
Why does masking a negative number produce a positive number?
在c++中,我有以下代码:
int x = -3;
x &= 0xffff;
cout << x;
这生产
65533
但是如果我去掉负号,就有了这个
int x = 3;
x &= 0xffff;
cout << x;
我简单地得到3
作为结果
为什么第一个结果不产生负数?我希望-3是扩展到16位的符号,考虑到所有扩展的位都是1,它仍然会得到一个2补的负数。因此,最高有效位也是1。
看起来您的系统使用32位int
和二进制补码表示负数。
常数0xFFFF
覆盖最不重要的两个字节,上面两个字节为零。
-3
的值是0xFFFFFFFD
,所以用0x0000FFFF
屏蔽它,你得到0x0000FFFD
,或者十进制的65533
。
正3
是0x00000003
,所以用0x0000FFFF
屏蔽会得到3
。
如果您指定16位数据类型,您将得到您期望的结果,例如
int16_t x = -3;
x &= 0xffff;
cout << x;
在您的示例中,int大于2个字节。您可能运行在现代CPU上,通常这些天的整数是4字节(或32位)
如果你看一下系统存储负数的方式,你会发现它是一个互补数。如果你只取最后2字节作为你的掩码是0xFFFF,那么你只会得到它的一部分。
你的2个选项:
- 使用short代替int。通常是整数的一半,只需要2个字节
- 使用更大的掩码,如0xFFFFFFFF,它覆盖了你的整数的所有位
注意:我使用"通常"是因为int和short的位数取决于你的CPU和编译器。
相关文章:
- 如何创建一个CMake变量,除非显式重写,否则使用默认值
- 删除一个线程上有数百万个字符串的大型哈希映射会影响另一个线程的性能
- 为什么两个不同的未命名名称空间可以共存于一个cpp文件中
- 运行同一解决方案的另一个项目的项目
- 挂起和取消挂起一个文件DLL
- 用C++中的一个变量定义一个常量
- 函数向量_指针有不同的原型,我可以构建一个吗
- 在c++中用vector填充一个简单的动态数组
- 如何在选项卡视图Qt中设置一个新项目,并保存以前的项目
- 预处理器:插入结构名称中的前一个行号
- 我在c++代码中生成了一个运行时#3异常
- 我想将一个对T类型的非常量左值引用绑定到一个T类型的临时值
- 从链接列表c++中删除一个项目
- 告诉一个 const char 数组,除了编译时 C 样式的字符串外,它不以 '