二进制整数-原码反码补码-求反码时符号位是否取反?

二进制整数-原码反码补码-求反码时符号位是否取反?

二进制整数-原码反码补码-求反码时符号位是否取反?

说实话,我的脑海里一直,浮现一个奇怪的问题,就是在二进制整数求反码的时候,符号位到底是取反还是不取反?

印象中有时候取反也对,有时候不取反也对。直到今天,我看见一个视频,才恍然得知其中的缘由。实际上是:取反也对,不取反也对。看你通过什么途径来做。

我们通常的做法是:给一个正数,求其所对应的负数的补码,怎么求?

实际上有两种途径,(但两种途径背后的原理是一样的,只不过叫法不一样)

途径1:正数二进制-----负数原码-----负数反码-----负数补码

我们给一个正数3的二进制:0011

他所对应的负数-3的原码是:1011

然后-3的原码对应的的反码是:1100 (此时我们发现,这里是符号位不取反的)

然后,该反码对应的补码是:1101 (也就是我们常说的:反码+1)

途径2:正数二进制—取反----对取反结果 +1

我们给一个正数3的二进制:0011

这个二进制取反得: 1100 (这里,符号位是取反了的)

将取反的结果 +1 得: 1101

我们发现,两种结果都一样,符号位取反不取反,结果都对。大佬们自然知道其中为什么会是这样,但是菜鸡的我们早已经绕的稀里糊涂。

根本原因在于:第二种途径,符号位都取反后,我们总是把他叫做反码,实际上这种叫法是不对的,这也是导致所有人迷惑的原因。

真正的反码是相对于负数原码来说的,没有原码的概念,不是对原码取反得到的结果,也就不能叫叫反码。

因此,严格点说,第二种途径不能将取反的结果称作反码,只能单纯的叫“取反的结果”

但是,第二种途径真的很好用,他是一种正数的补码和负数的补码互相转换的方法(正数的补码就是他的原码):

任何两个相反数的补码的相互转换,都可以用 “先全部取反,再+1”的方法来。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值