c语言编程必考题目之一

整型数据在内存中是以二进制的补码形式存放的问题

int i=-20;
unsigned int j=10;

在vc中编译:
若采用printf("%d", i+j);结果是:-10
若采用printf("%u", i+j);结果是:4294967286

解析:
整形数据在内存中存放二进制补码。所以数据的运算可以理解为是补码运算。
-20 的原码为:
10000000 00000000 00000000 00010100 原码
11111111 11111111 11111111 111 01011 反码
11111111 11111111 11111111 111 01100 补码

10 的补码为(正数的补码原码反码都相同):
00000000 00000000 00000000 00001010

i=-20 unsigned j=10
i+j

   11111111      11111111      11111111  111 01100 
  • 00000000 00000000 00000000 00001010

= 11111111 11111111 11111111 11110110

所以i+j 的补码为: 11111111 11111111 11111111 11110110

虽然计算机存放的是补码,但输出的是原码对应的数值,最高位符号为为1,表示运算结果为负数,将i+j的补码转化为原码:(-1取反)
得:
11111111 11111111 11111111 11110110

  •                                                                                   1
    

    11111111     11111111      11111111     11110101

取反后为: 10000000 00000000 00000000 00001010 对应二进制数为-10,所以运算结果为-10。

至于以%u (无符号输出) 可以这样理解:无符号数是没有符号位的,都是正数。
i+j 的补码为: 11111111 11111111 11111111 11110110

所以以符号数形式输出时,输出的就是对应二进制数的大小。
即: 11111111 11111111 11111111 11110110的数值大小。

如果把这个二进制数当全是1 计算的话数值大小为 2^32-1 ,当我们当全1计算的话多加了9,所以其运算结果为2^32-1-9 = 4294967286

以上使自己的简单理解,希望对你有帮助,如有错误,欢迎指正交流。

你可能感兴趣的:(c)