计算器运算使用的是加法器(不同于数学上减法同于加上一个负数的概念,以补码为例:-1其实是等于+255,而不是数学上的+(-1),这涉及到模的概念,不要记混。也正是因为这样,减法器才显得不那么必要)
这样的话,原码进行减法计算会有什么问题,看下:
例如1 - 1 = [00000001]原 + [10000001]原 = [10000010]原 = -2
明显结果不对,怎么办?看下反码运算。(这里请先了解一下反码,补码的概念,补码我的文章有记录,反码不多介绍,用的少)
对于正数:原码、反码、补码是一样的
例一:1-1=0
1 - 1 = [0000 0001]原 + [1000 0001]原= [0000 0001]反 + [1111 1110]反 = [1111 1111]反 =[1000 0000]原 = -0
这样,上面的1-1就可以得到正确结果了。
例二:2-1=1 (0010-0001)
2 - 1 = [0000 0010]原 + [1000 0001]原= [0000 0010]反 + [1111 1110]反
反码算数运算:两个数进行二进制反码求和的运算很简单。它的规则是从低位到高位逐列进行计算。0和0相加是0,0和1相加是1,1和1相加是0,但要产生一个进位1,加到下一列。如果最高位相加后产生进位,则最后得到的结果要加1。
用反码运算,其运算结果亦为反码。在转换为真值时,若符号位为0,数位不变;若符号位为1,应将结果求反才是其真值。
[0000 0010]反 + [1111 1110]反=[0000 0001]反= 1
例三:2-5=-3(0010+1101)
加上符号位
0010+1101= [0010]反 + [1010]反=[1100]反=[1011]原=-3
java中数值的存储主要是补码,下一章主要介绍补码。反码计算简单了解即可