int值是否通常转换为unsigned?

时间:2015-10-26 02:55:45

标签: c++ int unsigned

这是来自 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

如果我们在算术表达式中同时使用intunsigned值,unsigned值是否始终转换为int

1 个答案:

答案 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

感兴趣