-
先求取1的取反,也就是将1的二进制数1变成0,0变成1.
1的源码为 00000000 0000000 0000000 00000001 1的取反为 11111111 11111111 11111111 11111110
-
接下来就是对1取反的数进行分析
11111111 11111111 11111111 11111110这个数我们不知道是那个数,但我们知道它是一个负数,因为最左侧为1是符号位,表示负数。而在计算机中,无论正数还是负数都是以补码的形式进行加减运算的,也就是说11111111 11111111 11111111 11111110在这里是一个补码,我们需要将它转换为源码,才知道这个整数。下面进行负数的源码、反码、补码转化(正数的源码、反码、补码是相同的,这里不过多解说):
(-50)10的8为二进制原码为(10110010)2
(-50)10的8为二进制反码为(11001101)2 这里是将所有除了符号位的数按位取反
(-50)10的8为二进制补码为(11001110)2 这里是将上面的反码加一
由上面对负数源码的学习,可以得知要想求 11111111 11111111 11111111 11111110,先对其减一,然后取反.
减一后得到反码为 11111111 11111111 11111111 11111101
取反后得到源码为 10000000 0000000 0000000 00000010
也就是源码为-2
最终答案1的取反为-2 -
总结:
3.1 先对正数求补码
3.2 然后对补码取反,包括符号位
3.3 最后进行一个补码求原码的过程,一定要搞清概念啊。