在计算机内部,所有信息都是用二进制数串的形式表示的。整数通常都有正负之分,计算机中的整数分为无符号的和带符号的。无符号的整数用来表示0和正整数,带符号的证书可以表示所有的整数。由于计算机中符号和数字一样,都必须用二进制数串来表示,因此,正负号也必须用0、1来表示。通常我们用最高的有效位来表示数的符号(当用8位来表示一个整数时,第8位即为最高有效位,当用16位来表示一个整数时,第16位即为最高有效位。)0表示正号、1表示负号,这种正负号数字化的机内表示形式就称为“机器数”,而相应的机器外部用正负号表示的数称为“真值”。将一个真值表示成二进制字串的机器数的过程就称为编码。

无符号数没有原码、反码和补码一说。只有带符号数才存在不同的编码方式。

带符号整数有原码、反码、补码等几种编码方式。原码即直接将真值转换为其相应的二进制形式,而反码和补码是对原码进行某种转换编码方式。正整数的原码、反码和补码都一样,负数的反码是对原码的除符号位外的其他位进行取反后的结果(取反即如果该位为0则变为1,而该位为1则变为0的操作)。而补码是先求原码的反码,然后在反码的末尾位加1后得到的结果,即补码是反码+1。IBM-PC中带符号整数都采用补码形式表示。(注意,只是带符号的整数采用补码存储表示的,浮点数另有其存储方式。)

采用补码的原因或好处如下,采用补码运算具有如下两个特征:

1)因为使用补码可以将符号位和其他位统一处理,同时,减法也可以按加法来处理,即如果是补码表示的数,不管是加减法都直接用加法运算即可实现。

2)两个用补码表示的数相加时,如果最高位(符号位)有进位,则进位被舍弃。

这样的运算有两个好处:

1)使符号位能与有效值部分一起参加运算,从而简化运算规则。从而可以简化运算器的结构,提高运算速度;(减法运算可以用加法运算表示出来。)

2)加法运算比减法运算更易于实现。使减法运算转换为加法运算,进一步简化计算机中运算器的线路设计。

下面深入分析上面所陈述的采用补码的原因(目的)。

用带符号位的原码进行乘除运算时结果正确,而在加减运算的时候就出现了问题,如下:假设字长为8bits

( 1 ) 10- ( 1 )10 = ( 1 )10 + ( -1 )10 = ( 0 )10

(00000001)原+ (10000001)原= (10000010)原= ( -2 )显然不正确.。

因为在两个整数的加法运算中是没有问题的,于是就发现问题出现在带符号位的负数身上,对除符号位外的其余各位逐位取反就产生了反码。反码的取值空间和原码相同且一一对应。下面是反码的减法运算:

( 1 )10 - ( 1 ) 10= ( 1 ) 10+ ( -1 ) 10= ( 0 )10

(00000001)反+ (11111110)反= (11111111)反= ( -0 )有问题。

( 1 )10 - ( 2)10 = ( 1 )10 + ( -2 )10 = ( -1 )10

(00000001)反+ (11111101)反= (11111110)反= ( -1 )正确

问题出现在(+0)和(-0)上,在人们的计算概念中零是没有正负之分的。

于是就引入了补码概念。负数的补码就是对反码加一,而正数不变,正数的原码反码补码是一样的。在补码中用(-128)代替了(-0),所以补码的表示范围为:

(-128~0~127)共256个。

注意:(-128)没有相对应的原码和反码,(-128) = (10000000)补码的加减运算如下:

( 1 ) 10- ( 1 ) 10= ( 1 )10 + ( -1 )10 = ( 0 )10

(00000001)补+ (11111111)补= (00000000)补= ( 0 )正确

( 1 ) 10- ( 2) 10= ( 1 )10 + ( -2 )10 = ( -1 )10

(00000001)补+ (11111110)补= (11111111)补= ( -1 )正确

采用补码表示还有另外一个原因,那就是为了防止0的机器数有两个编码。原码和反码表示的0有两种形式+0和-0,而我们知道,+0和-0是相同的。这样,8位的原码和反码表示的整数的范围就是-127~+127(11111111~01111111),而采用补码表示的时候,00000000是+0,即0;10000000不再是-0,而是-128,这样,补码表示的数的范围就是-128~+127了,不但增加了一个数得表示范围,而且还保证了0编码的唯一性。

整数和0的原码、反码和补码都相同,下面介绍手工快速求负数补码的方法。这个方法在教材的第8页已经提到了,这里再写出来以便能引起大家的注意。其方法如下:

先写出该负数的相反数(正数),再将该正数的二进制形式写出来,然后对这个二进制位串按位取反,即若是1则改为0,若是0则改为1,最后在末位加1。

接下来的问题是,如何能将减法运算转换成加法运算呢?

我们已经知道,原码表示简单直观,与真值转换容易。但如果用原码表示,其符号位不能参加运算。在计算机中用原码实现算术运算时,要取绝对值参加运算,符号位单独处理,这对乘除运算是很容易实现的,但对加减运算是非常不方便的,如两个异号数相加,实际是要做减法,而两个异号数相减,实际是要做加法。在做减法时,还要判断操作数绝对值的大小,这些都会使运算器的设计变得很复杂。而补码这种编码方式实际上正是针对上述问题的。通过用补码进行表示,就可以把减法运算化为加法运算。

在日常生活中,有许多化减为加的例子。例如,时钟是逢12进位,12点也可看作0点。当将时针从10点调整到5点时有以下两种方法:

一种方法是时针逆时针方向拨5格,相当于做减法:

10-5=5

另一种方法是时针顺时针方向拨7格,相当于做加法:

10+7=12+5=5(MOD 12)

这是由于时钟以12为模,在这个前提下,当和超过12时,可将12舍去。于是,减5相当于加7。同理,减4可表示成加8,减3可表示成加9,…。

在数学中,用“同余”概念描述上述关系,即两整数A、B用同一个正整数M(M称为模)去除而余数相等,则称A、B对M同余,记作:

A=B(MODM)

具有同余关系的两个数为互补关系,其中一个称为另一个的补码。当M=12时,-5和+7,-4和+8,-3和+9就是同余的,它们互为补码。

从同余的概念和上述时钟的例子,不难得出结论:对于某一确定的模,用某数减去小于模的另一个数,总可以用加上“模减去该数绝对值的差”来代替。因此,在有模运算中,减法就可以化作加法来做。

可以看出,补码的加法运算所依据的基本关系为:

[x]补+ [y]补= [x+y]补

补码减法所依据的基本关系式:

[x-y]补=[x+(-y)]补= [x]补+ [-y]补

至于加法运算为什么比减法运算易于实现以及CPU如何实现各种算术运算等问题,则需要通过对数字电路的学习来理解CPU的运算器的硬件实现问题的相关内容了。

补充:

一、八位表示的范围:【有符号整数只能由其补码表示】

-128 --- -1 或10000000 - 11111111

0 ---- 127  或00000000 - 01111111

注意:0的机器码只有唯一的一种表示(编码),即00000000;没有-0这种说法,10000000不是-1的编码,而是-128的编码 ;另外10000000没有补码和反码。

二、编码

有真值(一般为十进制有符号整数)到机器码的转换过程称为编码。

三、计算机采用补码表示的原因

1)使符号位能与有效值部分一起参加运算,从而简化运算规则。从而可以简化运算器的结构,提高运算速度;(减法运算可以用加法运算表示出来。)

2)加法运算比减法运算更易于实现。使减法运算转换为加法运算,进一步简化计算机中运算器的线路设计。【从补码运算的特征理解!】

3)为了防止0的机器数有两个编码。

为什么通用计算机多采用补码,为什么计算机用补码存储数据?相关推荐

  1. 计算机组成用变形补码运算,计算机组成原理补码加减法运算

    计算机组成原理补码加减法运算 (37页) 本资源提供全文预览,点击全文预览即可全文预览,如果喜欢文档就下载吧,查找使用更方便哦! 14.90 积分 补码加减法运算 2019年7月9日计算机组成原理 1 ...

  2. 微型表格计算机,excel表格存储数据的最小单位-计算机中存储数据的最小单位是什么?...

    计算机中存储数据的最小单位和存储容量的基本单位... 位(bit)是制数的本单位,存储器存储信息的最小单位,8位二进制数称为字节(byte).当一个数作为一个整体存入或取出时,这个数叫做存储字.存储字 ...

  3. -7的补码用计算机,补码计算器-计算机求补码

    在计算机中,负数以其正值的补码形式表达. 什么叫补码呢?这得从原码,反码说起. 原码:一个整数,按照绝对值大小转换成的二进制数,称为原码.5的反码:将二进制数按位取反,所得的新二进制数称为原二进制数的 ...

  4. 计算机是如何存储数据的?

    为什么需要知道 我一个前端为什么需要知道这些东西.我想,这取决于你如何定义前端.如果定义是写页面的.切图的,那或许确实没必要:但如果你定义为程序员,那这就是必要的. To be a programme ...

  5. 计算机采用补码存储数据吗,为什么计算机用补码存储数据?

    来自公众号:漫话编程 关于作者:漫话编程,是一个通过漫画+音频的形式讲解枯燥的编程知识的公众号.致力于让编程变得更有乐趣. img img img img img img img 我们知道,计算机只认 ...

  6. 漫画:为什么计算机用补码存储数据?

    作者 | 漫话编程 来源 | 漫话编程(ID:mhcoding) 我们知道,计算机只认识0和1,现实世界中的内容,无论是文字.音频.视频等等想要通过计算机存储.计算或者展示,都需要转换二进制. 就像你 ...

  7. verilog设计一个补码加减法运算器_漫画:为什么计算机用补码存储数据?

    作者 | 漫话编程来源 | 漫话编程(ID:mhcoding)我们知道,计算机只认识0和1,现实世界中的内容,无论是文字.音频.视频等等想要通过计算机存储.计算或者展示,都需要转换二进制.就像你刚刚唱 ...

  8. 什么是现代通用计算机的轴型,大学计算机基础(版)各章节习题+答案.doc

    大学计算机基础(版)各章节习题答案 第一章 计算机与信息社会基础知识 一.选择题 1._____________是现代通用计算机的雏形. A. 宾州大学于1946年2月研制成功的ENIAC B.查尔斯 ...

  9. 漫话:为什么计算机用补码存储数据?

    作者 | 漫话编程 来源 | 漫话编程 我们知道,计算机只认识0和1,现实世界中的内容,无论是文字.音频.视频等等想要通过计算机存储.计算或者展示,都需要转换二进制. 就像你刚刚唱的旋律,想要存储在计 ...

最新文章

  1. CSS的六种垂直居中
  2. 阿里云上的docker安装
  3. [Ajax] 超于json2.js的版本json3.js
  4. python命令行运行django项目, can‘t open file ‘manage.py‘ 问题解决
  5. 学堂在线《sql server轻松学》数据库第5-8章习题答案
  6. 计算机网络管理员是技能培训吗,计算机网络管理员(路由与交换) 专业简介
  7. matlab:圆形的图像识别(二)
  8. 直线分割平面的公式_折线(含直线)分割平面(图文)解析
  9. ZEMAX | 使用 ZPL 宏进行优化:ZPLM 操作数
  10. 51nod1007:正整数分组 DP
  11. 计算机算法在生物信息学中的应用,引力场算法及其在生物信息学中的应用
  12. 三维荧光平行因子学习记录--(四)平行因子组件导出--(一)
  13. Java开发花三个月狂刷“面试宝典”成功从小厂35K跳槽到阿里50K
  14. IDEA —— Debug调试模式
  15. 春招面试(1)- 中科院软件中心/中科院自动化研究所
  16. H710 RAID卡的直通
  17. 【Sofice小司笔记】5 计算机网络,包含数据传输原理、网络各层协议详细说明、TCP/IP协议栈各常用协议说明、TCP握手挥手、可靠传输、网络加密技术
  18. vim增加php自动补全
  19. 勒索软件Snatch攻击原理分析
  20. 电脑市场Ghost XP SP2纯净版v3.0

热门文章

  1. 服务器系统安装与设置方法,服务器系统安装与设置
  2. opencv 图片对比(相似度)
  3. Tiled怎么导出瓷砖图片,做到和TileCspriteGen.exe一致的效果?
  4. android 同时实现微信分享和微信登录功能
  5. ROS下使用乐视RGB-D深度相机/Orbbec Astra Pro显示图像和点云
  6. 关于Vue2.0中引入jQuery
  7. JavaScript函数式编程指南
  8. http://blog.csdn.net/KBUG/archive/2006/10/30/1357009.aspx
  9. SQL---DQL语言之分组函数(聚合函数)
  10. python 视频转场_利用Python 进行短视频的二次创作