您当前的位置: 首页 > 

liaowenxiong

暂无认证

  • 4浏览

    0关注

    1171博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

反码、原码、补码的观点阐述

liaowenxiong 发布时间:2021-01-20 09:12:50 ,浏览量:4

我自己是不认可所谓的原码、反码的说法,但是很多人在计算负数的二进制时,都会使用反码和原码的概念,我这里就简单梳理下吧。

十进制2的二进制数(按8位的二进制举例)如下: 原码:0000 0010 补码:0000 0010 没有反码。有人说反码也是0000 0010,简直瞎扯!

十进制-2的二进制数如下: 原码:1000 0010,最高位是符号位,0表示正数,1表示负数,所以-2的符号位是1 反码:1111 1101,对原码取反,但是符号位不动 补码:1111 1110,反码+1,就得到-2的补码,实际计算机存储的就是补码,没有什么反码、原码之类的。

总结:正数的原码就是补码,所以不需要取反+1,而负数的原码不是补码,所以需要取反+1得到补码。而如果是负数的补码则可以-1取反得到原码,注意取反时符号位不动。

为什么我不认可这些概念?

因为二进制运算规则已经确定了,就是采用补码规则,在规定的位数范围内计算,而且计算机内保存的都是补码,所以就没有必要讲什么原码、反码之类的东西了。只要记住二进制正数和负数的转换计算规则即可,取反+1

所以我的观点就是: 2的二进制数:0000 0010 ,这就是2的补码,没有所谓的”原码“ -2的二进制数,就是2的二进制数取反+1,得到:1111 1110,这就是-2的补码,没有所谓的”原码“、”反码“。

关注
打赏
1661566967
查看更多评论
立即登录/注册

微信扫码登录

0.0445s