原码、反码、补码的学习窍门

首先要明确,定点小数、定点整数均可用这三种编码来表示,在学习这几种编码时有下述两个技巧:

技巧一

     不管是定点小数、定点整数,编码总位数相同的情况下,补码的表数个数总比原码、反码多一个,原因在于,真值0对应的原码、反码有两个编码(对应负零和正零),而真值0的补码只有一个。这就造成了同等条件下,补码的表数范围跟其他两种不一样,例如,当总编码位数(包含符号位)为8时,补码的表数范围为:-27≤X≤27-1,而原码、反码的表数范围为:-27-1≤X≤27-1。因此,此时,27=128有补码,却没有原码、反码。作为一种特例,真值“-1”被纳入定点小数补码的表数范围中,即定点小数补码的表数范围为:-1≤X<1,而定点小数原码、反码的表数范围为::-1<X<1(不包含-1)。

技巧二

     不管是定点小数、定点整数,在求各种编码时,都可遵循以下原则:正数的原码、反码、补码的符号位均为0原码、反码、补码数值位均为数值本身;负数的原码、反码、补码的符号位均为1,原码的数值位为数值本身,反码的数值位为数值本身(即原码数值位)各位取反,而补码的数值位是在反码数值位的基础加1若数值最高位有进位则丢弃(不向符号位进位)。

例如,当编码总位数为8时有:

+127的原码、反码、补码都为:0 1111111。

-127的原码、反码、补码依次为:1 1111111、1 0000000、1 0000001。

+0、-0的原码分别为:0 0000000、1 0000000,均对应真值0。

由于“编码总位数为8”的限制,真值-128无法用原码、反码来表示,似乎不能用上述规则来求解补码,但实际上是可行的——只要不管它的最高位即可,操作办法如下:

将128化为二进制为:1 0000000,最高位为1,可以只对舍去最高位后剩余的7位进行处理即可,首先取反得:1111111,加1得:1 0000000,最高位有进位需丢弃,即得:0000000,加上符号位就得补码:1 0000000。

又如,当编码总位数为4时,真值X=+0.101的原码、反码、补码均为:0 101。

真值X=-0.101的原码、反码、补码依次为:1 101、1 010、1 011。

同理,特例,-1的补码为:1 000。

在定点小数中,小数点隐含在第一位编码和第二位编码之间。

                                                                  来源:刘智成原创

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值