补码在计算机系统中有什么重要作用

 我来答
沙里波特
2021-09-21 · TA获得超过5251个赞
知道大有可为答主
回答量:1.1万
采纳率:95%
帮助的人:638万
展开全部

计算机中补码的作用,要从常识中“补数”来理解。

对于钟表,倒拨 3 小时,可以用正拨 9 小时来代替。

对于两位十进制数,共有 100 个数:0~99。

减一,就可以用 +99 代替。

如:28-1 = 27

  28 + 99 = (1) 27

忽略 100,结果就相同了。

那么,9 就是-3 的补数、99 就是-1 的补数。

补数,就是用数值较大的正数,代替负数。

利用补数,就可以用加法,代替减法运算。

--------

补码,就是二进制形式的补数。

计算机中八位补码,共有 256 种组合。

那么,负数的补码就是:256 + 这个负数。

那么,数字-1 的补码就是:1111 1111 = 255(十进制)。

同理,数字-2 的补码就是:1111 1110 = 254。

。。。

最终,数字-128 的补码就是:1000 0000 = 128。

求补码,并不需要原码反码。

计算机中,根本也没有原码反码。

原码反码,是毫无用处的东西。

--------

用补码代替负数,就可用加法代替减法运算。

计算机中,只要具有加法器,就够用了。

这就可以简化计算机系统的硬件。

wasxsfdx
2018-05-14
知道答主
回答量:1
采纳率:0%
帮助的人:871
展开全部

发现网上对这个问题的回答都不甚完善,特专门打字口语化回复。

通过原码可以很便捷的实现将现实世界中的数值转换为二进制01序列保存在计算机中,但原码对于计算机中01序列数值的加减法运算难以高效支持。所以为了运算需要,必须要将数值以补码形式保存在计算机中,补码有三个重要意义:

  1. 补码可以很方便的将减法运算转换为加法运算,硬件实现上,就只需要一个加法器即可完成加减法运算,无需再设计生产减法器。

  2. 补码加减法运算中,可以将符号位无差别的看成是数值,直接参与运算,最终得到的结果中最高位仍按符号位理解,并且计算结果无误。

  3. 补码消除了正负零的干扰,使得示数范围朝负方向上扩展一位,如将原码-127到+127的范围,扩展为-128到+127.

更多内容可关注我在百度文库中上传的计算机组成原理PPT课件。

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
WYZZWB2011407d2e
高能答主

2016-09-22 · 最想被夸「你懂的真多」
知道大有可为答主
回答量:5.2万
采纳率:77%
帮助的人:7659万
展开全部
计算机中的符号数有三种表示方法,即原码、反码和补码。三种表示方法均有符号位和数值位两部分,符号位都是用0表示“正”,用1表示“负”,而数值位,三种表示方法各不相同。
64位计算机, 所能表示的最大数是18446744073709551616,若再加1成为18446744073709551617,但因只有64位,最高位1自然丢失,又回了零,所以64位二进制系统的模为2^64。在这样的系统中减法问题也可以化成加法问题,只需把减数用相应的补数表示就可以了。把补数用到计算机对数的处理上,就是补码。
正整数的补码是其二进制表示,与原码相同。
求负整数的补码,将其对应正数二进制表示所有位取反(包括符号位,0变1,1变0)后加1。同一个数字在不同的补码表示形式中是不同的。比如-15的补码,在8位二进制中是11110001,然而在16位二进制补码表示中,就是1111111111110001。以下都使用8位2进制来表示。
希望我能帮助你解疑释惑。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式