反码计算典型实例

        计算器运算使用的是加法器(不同于数学上减法同于加上一个负数的概念,以补码为例:-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中数值的存储主要是补码,下一章主要介绍补码。反码计算简单了解即可

 

 

 

  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值