计算机/数字ic基础知识

原文链接:https://blog.csdn.net/qq_28632639/article/details/97269103

负数原码与补码之间相互转换

背景:计算机内部用补码表示二进制数。符号位 1 表示负数,0 表示正数。

正数:无区别,正数 的原码= 反码 = 补码

重点讨论负数
若已知 负数 -8,则其

原码为:1000 1000,(1为符号位,为1代表负数,为0代表正数)

反码为:1111 0111,(符号位保持不变,其他位置按位取反)

补码为:1111 1000,(反码 + 1)

即在计算机中 用 1111 1000表示 -8

若已知补码为 1111 1000,如何求其原码呢?

(1)方法1:求负数 原码—>补码 的逆过程。

    注意:符号位保持不变!

(A)先 - 1,得到 1111 0111

(B)取反(符号位保持不变,其他位置按位取反 ),得到 1000 1000

(2)方法2:

    注意:符号位保持不变!

(A)将这个二进制数中(即 1111 1000),除了符号位,其余位置按位取反,得 1000 0111

(B)+ 1,得到 1000 1000

总结:
-1 后,再取反 和 取反后,再+1 的效果是一样的。

   这就和  -(3-1)  和 (-3 +1) 是一个道理。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值