如 int num=~3+2;
结果num的值为-2。
~3的结果是-12(8位举例。PS:原谅我没换为int32位的,数值太大了)。
-12的补码是取反加+,结果为-4。
2的补码还是2。
补码(two's complement)
1、在计算机系统中,数值一律用补码来表示(存储)。 主要原因:使用补码,可以将符号位和其它位统一处理;同时,减法也可按加法来处理。另外,两个用补 码表示的数相加时,如果最高位(符号位)有进位,则进位被舍弃。
2、补码与原码的转换过程几乎是相同的。
二进制的运算就是二进制的运算,补码只是方便人的理解而已。至于计算机具体实现,则是由数字逻辑电路组合而成的,你说它是补码也好,是反码也好,是原码也好,都是对它输入输出的一种便于理解的表达,换言之,只要你能得到纯数学意义上正确的答案,解题过程用什么方式去理解都可以。
差不多就是这样。
举个通俗的例子,就是手表(12进制)。
11 + 2 = 1
2的补码为-10,所以也是
11 -10 = 1