- 1、本文档共105页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第1章. 微型机系统的基础知识li
机器数与真值 在计算机中,数学上的“+”“-”符号被数字化。规定1个字节中的D7位为符号位,D0~D6位为数字位。在符号位中,用“0”表示正,“1”表示负,而数字位表示该数的数值部分。 例如: N1+91D N2-91D 1个数的数值和符号全都数码化了。我们把1个数(包括符号位)在机器中的一组二进制数表示形式,称为“机器数”,而把它所表示的值(包括符号)称为机器数的“真值”。 原码 原码即符号位用0表示正数,用1表示负数,其余数字位表示数值本身。 对于正数 X=+105的原码表示为: 〔X〕原= 0 1101001 对于负数 X=-105的原码表示为: 〔X〕原= 1 1101001 对于0,可以认为它是(+0),也可以认为它是(-0)。 〔+0〕原=0 0 0 0 0 0 0 0 〔-0〕原=1 0 0 0 0 0 0 0 反码 正数的反码表示与其原码相同,即符号位用“0”表示正,数字位为数值本身。 〔+0 〕反= 0 0 0 0 0 0 0 0 〔+4 〕反= 0 0 0 0 0 1 0 0 〔+31〕反= 0 0 0 1 1 1 1 1 〔+127〕反= 0 1 1 1 1 1 1 1 负数的反码是将它的正数按位(包括符号位在内)取反而形成的。 〔-010〕反= 1 1 1 1 1 1 1 1 〔-410〕反= 1 1 1 1 1 0 1 1 〔-3110〕反= 1 1 1 0 0 0 0 0 〔-12710〕反= 1 0 0 0 0 0 0 0 (1)“0”的反码有两种表示法示+0 示-0 (2)8位二进制反码能表示的数值范围为+127D~-127D。 (3)当一个带符号数用反码表示时,最高位为符号位。 符号位为0(即正数)时,后面的7位为数值部分;符号位为1(即负数)时,后面7位表示的并不是此负数的数值,而必须把它们按位取反以后,才得到表示这7位的二进制数值。 例:一个8位二进制反码表示的。它是一个负数;应先将其数字位按位取反,然后才能得出此二进制数反码所表示的真值: -1101011=-(1×26+1×25+1×23+1×21+1) =-(64+32+8+3) =-107D 8位二进制数反码特点 返回 补码 微机中都是采用补码表示法,因为用补码法以后,同一加法电路既可以用于有符号数相加,也可以用于无符号数相加,而且减法可用加法来代替。 (1)正数的补码 正数的补码与其原码相同。 〔+4〕补 = 0 0000100 〔+31〕补 = 0 0011111 〔+127〕补 = 0 1111111 (2)负数的补码 负数的补码表示为它的反码加1(即在其低位加1)。 〔-4〕补 = 1 1111100 〔-31〕补 = 1 1100001 〔-127〕补 = 1 0000001 (1)〔+0〕补=〔-0〕补(2)8位二进制补码所能表示的数值为+127~-128。 (3)若符号位为“0 ”(即正数)时,其余7位即为此数的数值本身;当符号位为“1”(即负数)时,必须将它们按位取反,且在最低位加1,才得到它的数值。 例:一个补码表示的数〔X〕补 它是一个负数。但它并不等于-1BD,它的数值为:将数字位0011011按位取反得到1100100,然后再加1,即为1100101。 X=-1100101 =-(1×26+1×25+1×22+1×20 =-(64+32+4+1) =-101D 8位二进制数补码的特点 8位机器数的对照表 在微机中,凡是带符号数一律用补码表示,运算结果也是补码。补码的加减运算特点:符号位与数字位一起参加运算,并且自动获得结果(包括符号位与数字位)。进行加法时,按两数补码的和等于两数和的补码进行。 〔X〕补+〔Y〕补=〔X+Y〕补 例1:已知X=+1000000,Y=+0001000, 〔X〕补〔Y〕补则 〔X〕补 +64 +)〔Y〕补 +)+ 8 〔X〕补+〔Y〕补 +72 所以,〔X+Y〕补(mod 28) 补码的加减法运算 例2:已
文档评论(0)