关于C语言中的无符号数和有符号数

发布时间:2011-09-16 共3页

  无符号数和有符号数是不能进行比较运算的,否则可能会出现意想不到的错误,且极难检查出来!

  首先肯几个例子(假设在32位的机器上):

  1         1. 0 == 0U

  2         2. -1 < 0U (注: 0是无符号的)

  3         3. 2147483647U > -2147483647 - 1

  4         4. 2147483647 > (int) 2147483648U

  结果如下:

  1         1. 1

  2         2. 0 *

  3         3. 0 *

  4         4. 1 *

  从结果中可以看出,2 3 4都不是我们想像中的结果。在C语言中,当一个无符号数和一个有符号数进行比较运算时,有符号数会被隐含的转换成无符号数,并假设这两个数都是非负数,然后进行比较运算。当把一个有符号数转换成无符号数时,其底层的二进制表示没有改变,仅仅是对其进行了不同的解释。这样,由于这两个原因就会出现上面的结果。

  首先分析一下2:

  -1的二进制补码表示是32个1。而0U的二进制补码表示是32个0.在比较的时候,-1被当做无符号数,也就是把32个1当做无符号数和32个0的无符号数比较,显然,32个1要大于32个0.所以,2的结果是1.

  再看看3,-2147483647的二进制补码表示是1000 0000 0000 0000 0000 0000 0000 0000, -1的补码表示是32个1,两个相加,也就是补码异或,得到0111 1111 1111 1111 1111 1111 1111 1111,这个结果是溢出的。由于前一个的操作数是无符号数,因此,前面的计算结果被当做无符号数来处理,因此,这两个数是相等的。所以结果是0.对于 4,2147483648U被转换成有符号数是-1,所以4的结果是1.

  从上面可以看出,无符号数和有符号数在进行比较的时候,如果数值在边界上,则很容易出错。

百分百考试网 考试宝典

立即免费试用