这是来自 C ++ Prime 5th :
如果我们在算术表达式中同时使用unsigned和int值,则int值通常会转换为unsigned。
我尝试了以下代码:
int i = -40;
unsigned u = 42;
unsigned i2 = i;
std::cout << i2 << std::endl; // 4294967256
std::cout << i + u << std::endl; // 2
对于i + u
,如果i
转换为unsigned
,则应为4294967256
,然后i + u
不能等于2
。
如果我们在算术表达式中同时使用int
和unsigned
值,unsigned
值是否始终转换为int
?
答案 0 :(得分:5)
是
您遇到的是整数溢出。负数的符号由前导符号位给出,其为0(正)或1(负)。但是,对于无符号整数,这个前导位只会给你一个整数精度位,而不是符号的指示。 &#34;负&#34;有符号数最终从最大无符号整数大小向后计数。
这与您的特定代码有何关系?好吧,-40确实变成4294967256.但是,4294967256 + 42不能适合无符号整数,好像你记得-40刚刚变成最大无符号整数减去39.所以加上42,你超过了数据类型的容量。想要的第33位被切断,你从0开始。因此,你仍然得到2作为答案。
Signed: -42, -41, ..., -1, 0, 1, 2
Unsigned: 4294967256, 4294967257, ..., 4294967295, 0, 1, 2, ...
^--^ Overflow!
您可能对阅读Two's Complement
感兴趣