有符号数和无符号数隐式转换

C++ Primer (5th)

无符号类型的运算对象 P142

1. 如果一个运算对象是无符号类型、另一个运算对象是带符号类型,而且其中的无符号类型不小于带符号类型,那么带符号类型的运算对象转换成无符号的。例如,假设两个类型分别为unsigned int 和 int ,则int类型的运算对象转换成unsigned int类型。                   

    unsigned u = 9;
    int i = -2;
    cout << u + i << endl; //7

当我们赋给无符号类型一个超出它表示范围的值时,结果是初始值对无符号类型表示数值总数(范围)取模后的余数。

  无符号类型数9 >= 有符号类型数-2,有符号类型数变为无符号类型数,则-2变成无符号数4294967294,和9做加法后得到4294967303,超出了32位无符号的最大值4294967295,则得到的值为4294967303 % 4294967296 = 7;

 

2.带符号类型大于无符号类型,此时转换的结果依赖于机器。如果无符号类型的所有值都能存在带符号类型中(带符号类型数据范围比无符号类型数据范围大),则无符号类型的运算对象转成带符号类型。3)如果不能,那么带符号类型的运算对象转换成无符号类型。

  long long u = -9;
    unsigned i = 3;
    cout << u + i << endl; //-6

  无符号类型数3 < 有符号类型数-9,且unsigned int类型的数都能在long long里面找到对应的数,因此无符号类型的数转化为有符号类型的数,结果为-9+3=-6;

 

3.

    int u = -9;
    unsigned i = 3;
    cout << u + i << endl; //4294967290        

无符号类型数3 < 有符号类型的数-9,但是unsigned int类型里面有一半的数在int类型里面找不到对应的数,因此有符号类型的数转化为无符号类型的数,-9转化为4294967287,加上3之后,结果就变为4294967290.

  因此,得出结论,书中p142页所讲的无符号类型的大小比较,其实是两个数的绝对值比较。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

上一篇:字符串编码Rabin-Karp算法Leetcode 1044. 最长重复子串


下一篇:基于STM32F103单片机的无线病床呼叫系统