计算机中补码的原理,计算机中,设计补码的思维方式与原理

1.补码的由来

因为计算机是由其电路的接通与关闭来控制的,也只能用0和1来分别表示开和关。所有人们设计出了二进制,顾名思义,逢二进一。

但当人们想表示负数的时候,有人提出,其数字的机器码前面多用一位来标记符号,0代表正数,1代表负数,这样对人们很友好。

但新的问题又出现了,比如当计算机求两个数的加减法运算时,两个正数相加可以计算,但当两个正数相减时,计算机却不那么地好计算了,为什么?因为两个数相减时,还的比较绝对值的大小,然后大数减去小数,最后计算出结果后,计算机还的给结果一个符号,是正的还是负的?这时,它就不知道该怎么办了?

2.提出补码的思维过程

后来有人提出这样一个想法。他这个想法我们很好理解,就是通过家里面的圆形钟表得来的。

比如现在5点钟了,他的表钟现在是7点钟,该怎么调?他发现用两种方式都行,第一种是逆时针旋转2格到5点,还有一种是顺时针旋转10格到达5点,由于他一直喜欢顺时针(时间通过秒针、分钟、时针的顺时针旋转而增加),因为一圈刚刚有12格,顺时针旋转过的角度加上逆时针旋转过的角度刚好等于360度,也就是12格,这是不变的。

他想到计算机也可以这样工作,他欣喜若狂,因为减法(逆时针)可以相当于加法了(顺时针),只不过他们的超过了的一圈还是个问题,不过有了这个想法了,就可以先试试,等到具体要解决时再考虑也不迟。

好了,这个想法应该可行,说干就干,开始设计。

他为了表示方便,把顺时针旋转的格数叫做逆时针旋转格数的补数。同理,在计算机中,所有的数字都是0和1,那用0和1表示的数字就叫做机器码,在这里的机器码就叫做补码了。

有了补码,他就能让计算机相减了,哈哈,终于大功告成了。以后再让计算机算诸如:y = 3-5的减法等式,他反手先算-5的补码,相当于y = 3 + [-5],式中的[-5]就是-5的补码。那[-5](-5的补码)这个是多少呢?计算机当然不知道了,那的看那个“表盘”有多少格,就比如上面那个例子,表盘12格,“-2”(逆时针旋转2格)的补码是“+10”(顺时针旋转10格)。

他拿十进制类比,0~9,10进制一圈是10格,逢十进一;

拿十六进制的话就是0x0000~0xffff(0~15),十六进制是16格,逢十六进一;

那,二进制的话,就是逢二进一(这是1位的前提)

好了,那现在规定计算机中,用一个字节(8位)来存放数字,那么如果换算成数字,这个“表盘”一圈是多大呢,是2的8次方 = 256格。

那现在,他可以毫不犹豫的说:-5的补码是[-5],即:

math?formula=%5B-5%5D%20%3D%20256-5%3D251

那如果要算:

math?formula=y%20%3D%203-5呢?

他就这样算:

math?formula=y%20%3D%203%2B%5B-5%5D%20%3D%203%20%2B%20251%20%3D%20254

等等,我们晕了,怎么 y = 3-5明明等于-2,他为什么算出的答案等于254?

聪明的你发现了,没错,就是254。-2的补码[-2]就是254,在计算机中,所有计算的数字都是按照补码形式参与运算的,只不过,正数的补码还是它本身罢了。

你恍然大悟,但依然若有所思,

等等,那照他说,计算机计算y = 3-5 是按照:

math?formula=y%20%3D%203-5%20%3D%203%2B%5B-5%5D%20%3D%203%20%2B%EF%BC%88256-5%EF%BC%89

这个等式计算的话,本来我们就是为了消除减法而提出补码的,怎么计算-5的补码[-5]时候,我们又用了减法 ,那不就是自相矛盾了吗?

能看到这一点,说明你已经理解了99%了,离成功就差一步了,

别慌,你仔细看(256-5)是个什么东西?

3.反码的提出

其实反码是计算补码的一个中间产物,是一个对于我们人来说多余的东西。

它专门为计算机计算补码提出的,我们有异常发达的大脑的人类当然不需要这玩意,为什么?请看下列:

在计算机中:

256表示:

math?formula=1%200%200%200%200%200%200%200%200%20%EF%BC%881%E5%90%8E%E9%9D%A28%E4%B8%AA0%EF%BC%8C%E6%80%BB%E5%85%B19%E4%BD%8D%EF%BC%89

5表示:

math?formula=0%200%200%200%200%201%200%201%20(%E6%80%BB%E5%85%B18%E4%BD%8D)

记住,我们是用8位存放数字的,怎么256超过9位了,这不行,这好想:“既然计算机不能表示256,那我就让计算机把256减去1后(我们头脑中的思维过程),刚好是255即1 1 1 1 1 1 1 1(8个1),让计算机用这8个1不就可以存储了吗吗?”。

然后就变成了下面这样的了:

math?formula=1%5Cspace1%5Cspace1%5Cspace1%5Cspace1%5Cspace1%5Cspace1%5Cspace1(8%E4%B8%AA1)

然后他拿这8个1减去5的机器码,即:

math?formula=%5Cbegin%7Baligned%7D%20%26%5Cspace%5Cspace%5Cspace%5Cspace%5Cspace1%5Cspace1%5Cspace1%5Cspace1%5Cspace1%5Cspace1%5Cspace1%5Cspace1%20%EF%BC%88255%EF%BC%89%5C%5C%20%26-0%5Cspace0%5Cspace0%5Cspace0%5Cspace0%5Cspace1%5Cspace0%5Cspace1%20%EF%BC%885%EF%BC%89%5C%5C%20%26%5Chline%5Cspace%5Cspace%5Cspace%5Cspace%5Cspace1%5Cspace1%5Cspace1%5Cspace1%5Cspace1%5Cspace0%5Cspace1%5Cspace%200%EF%BC%88250%EF%BC%89%20%5Cend%7Baligned%7D

那计算机计算这个就太容易了。按照我们小学生思维水平,上面减去下面就行了,但计算机发现,这就是一个取反位运算,马上就能计算出这个减法了。

这一思维的灵感是我想了一天后,在晚上爬到床上突然获得的,我一直再想为什么通过反码,然后加1就可以直接得到补码,原理是什么?大致过程是这样的:正好被减数都是1的话,减数加上它自己的每一位对应的取反,刚好对应相加就都是1了,相当于把原来那个数的所有0位置都填充上了1,换个角度说,这个刚好差1就是一圈了,这时,不就刚好相当于表盘逆时针和顺时针旋转格数相加,刚好等于一圈了吗?补码的原理不就是一圈一分为二,互为补数,这样才有了反码的,是不是很给力,请看下图的上下每一位,都有一个1,分别相加后,那不就是全部一圈差1吗

math?formula=%5Cboxed%7B%20%5Cbegin%7Baligned%7D%20%26%5Cspace%5Cspace%5Cspace%5Cspace%5Cspace%5Cspace1%5Cspace1%5Cspace1%5Cspace1%5Cspace1%5Cspace0%5Cspace1%5Cspace%200%EF%BC%88250%EF%BC%89%5C%5C%20%26%2B%5Cspace0%5Cspace0%5Cspace0%5Cspace0%5Cspace0%5Cspace1%5Cspace0%5Cspace1%20%EF%BC%885%EF%BC%89%5C%5C%20%26%5Chline%5Cspace%5Cspace%5Cspace%5Cspace%5Cspace%5Cspace1%5Cspace1%5Cspace1%5Cspace1%5Cspace1%5Cspace1%5Cspace1%5Cspace1%20%EF%BC%88255%EF%BC%89%5C%5C%20%5Cend%7Baligned%7D%20%7D

到这一步时,我们就计算出了(256-5)?,聪明的你已经发现了,是(255-5)而不是(256-5),因为刚才计算机不能表示256我们作出的妥协(我们人不需要,因为大脑多大的数字都能想到),现在我们再次把刚才减去的1加上就和原来的式子相等了,即:

math?formula=(256-5)%3D%20%5B(256-1)-5%5D%2B%201

到这一步,我们终于让计算机把这个-5的补码[-5]表示出来了(计算出来了),我们不妨回过头来总结一下,哦,我们发现,以后经常操作(256-1)-5这一步,我们给这一步叫做计算机求反码的过程,而计算的结果就叫做反码。

最后,我们发现让这个相反数+1就是我们求得的这个负数的补码。

4.数学结论(敲黑板)

老师说,记住了,求补码就是负数的符号位不变,其余的位数取反,然后加1。

其实,老师得出的结论是根据补码在数学上的定义得出的口诀,就像奇变偶不变,符号看象限一样的口诀。真正的数学公式如下:

math?formula=%5Bx%5D_%7B%5Cmathrm%7B%E8%A1%A5%7D%7D%3D%5Cleft%5C%7B%5Cbegin%7Barray%7D%7Bcl%7D%20x%20%26%20(%5Ctext%20%7B%20%E5%BD%93%20%7D%20x%20%5Ctext%20%7B%20%E4%B8%BA%E6%AD%A3%E6%95%B0%20%7D)%20%5C%5C%202%5E%7Bn%7D-x%20%26%20(%5Ctext%20%7B%20%E5%BD%93%20%7D%20x%20%5Ctext%20%7B%20%E4%B8%BA%E8%B4%9F%E6%95%B0%20%7D)%20%5Cend%7Barray%7D%5Cright.

如果我们把刚才求反码的过程也加上去,就是这样的:

math?formula=%5Bx%5D_%7B%5Cmathrm%7B%E8%A1%A5%7D%7D%3D%5Cleft%5C%7B%5Cbegin%7Barray%7D%7Bcl%7D%20x%20%26%20(%5Ctext%20%7B%20%E5%BD%93%20%7D%20x%20%5Ctext%20%7B%20%E4%B8%BA%E6%AD%A3%E6%95%B0%20%7D)%20%5C%5C%20%5B(2%5E%7Bn%7D-1)-x%5D%20%2B%201%20%26%20(%5Ctext%20%7B%20%E5%BD%93%20%7D%20x%20%5Ctext%20%7B%20%E4%B8%BA%E8%B4%9F%E6%95%B0%20%7D)%20%5Cend%7Barray%7D%5Cright.

整篇文章,为了讲清楚这个补码的思维原理,码字时间就花费了3个多小时,很辛苦,如果对你有帮助,能否点个赞鼓励一下再离开。俗话说,往往点赞的人,运气永远不会错到哪里的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值