C语言中有符号数与无符号数相加

xiaoxiao2021-02-28  113

执行以下这段程序,输出的结果是什么?

#include <stdio.h>

int main()

{     unsigned int a = 1;     signed int b = -2;     printf("%d\n", a + b);     printf("%u\n", a + b);        return 0;

}

计算机中的加法运算是通过加数补码相加实现的。

程序中,a为无符号整型数,其补码为0000 0001(方便起见,这里仅用8位表示,下文同理),起始位的“0”表示数值;b为有符号整型数,其补码为1111 1110,起始位的“1”表示正负。

将变量a和变量b的补码相加,得到1111 1111。

printf("%d\n", a + b)中,由于%d的作用,使a+b以有符号十进制的形式输出,此时,最高位的1为符号位,减一取反得到其原码,得到1000 0001,即十进制的-1;

printf("%u\n", a + b)中,由于%u的作用,使a+b以无符号十进制的形式输出,此时,最高位的1并非符号位,其表示数值大小,不用减一取反,得到1111 1111,实际Linux系统中,该数用4个字节表示,也就是说实际上这里有16个"1",即十进制数的4294967295(=2^32-1)。

综上,该段程序的输出结果为:

-1

4294967295

转载请注明原文地址: https://www.6miu.com/read-66495.html

最新回复(0)