ch计算机中的数制和编码实用.pptx
1计算机中的数制和编码 计算机的基本功能是进行数据和信息的处理。数据、信息以及为处理这些数据和信息而编写的程序的代码都必须输入到计算机中。由于电子器件容易实现对两种状态的表示,因此,计算机中的数字、字符和指令等一般都使用二进制编码来表示。在第2章中,将介绍无符号数的表示方法、各种数制的相互转换以及二进制数的运算规则等;将重点介绍带符号数的表示方法、补码加减法运算预计运算溢出的判断方法;最后介绍十进制数的BCD编码和字符(包括字母、数字和符号)的ASCII编码;介绍数的定点和浮点表示方法。第1页/共103页22.1无符号数的表示及运算2.1.1无符号数的表示方法1.十进制数的表示方法十进制计数法的特点是:逢十进一;使用10个数字符号(0,1,2,9)的不同组合来表示一个十进制数;以后缀D或d表示十进制数(Decimal),但该后缀可以省略。第2页/共103页3任何一个十进制数可表示为:式中:m表示小数位的位数,n表示整数位的位数,Di为第i位上的数符(可以是09十个数字符号中的任一个)。例2.1138.5(D)=第3页/共103页42.二进制数的表示方法二进制计数法的特点是:逢二进一;使用2个数字符号(0,1)的不同组合来表示一个二进制数;以后缀B或b表示二进制数(Binary)。任何一个二进制数可表示为:式中:m为小数位的位数,n为整数位的位数,Bi为第i位上的数符(0或1)。例2.21101.11B=第4页/共103页53.十六进制数的表示法十六进制数的表示法十六进制计数法的特点是:逢十六进一;使用16个数字符号(0,1,2,3,9,A,B,C,D,E,F)的不同组合来表示一个十六进制数,其中AF依次表示1015;以后缀H或h表示十六进制数(Hexadecimal)。第5页/共103页6任何一个十六进制数可表示为:式中:m为小数位的位数,n为整数位的位数,Hi为第i位上的数符(可以是0,1,,9,A,B,C,D,E,F十六个数字符号中的任一个)。例2.30E5AD.BFH=第6页/共103页7一般来说,对于基数为的任一数可用多项式表示为:(2.1.4)式中:X为基数,表示X进制;i为位序号;m为小数部分位数;n为整数部分的位数;ki为第i位上的数值,可以为0,1,2,X-1共X个数字符号中任一个;Xi为第i位的权。第7页/共103页82.1.2各种数制的相互转换1任意进制数转换为十进制数二进制、十六进制以至任意进制数转换为十进制数的方法很简单,只要按式2.1.2,2.1.3和2.1.4各位按权展开(即该位的数值乘于该位的权)求和即可。第8页/共103页92.十进制数转换成二进制数1)整数部分的转换下面通过一个简单的例子对转换方法进行分析。例如,B2B3B0B2B1B0B3B1可见,要确定13D对应的二进制数,只需从右到左分别确定系数B0,B1,B2,B3即可。第9页/共103页10式(2.1.5)右侧除以2:商为,余数为1,此余数即为B0;商再除以2:商为,余数为0,此余数即为B1;商再除以2:商为,余数为1,次余数即为B2;商再除以2:商为(商为0时停止),余数为1,此余数即为B3。第10页/共103页11由以上过程可以得出十进制整数部分转换为二进制数的方法:除以基数(2)取余数,先为低位(B0)后为高位。显然,该方法也适用于将十进制整数转换为八进制整数(基数为8)、十六进制整数(基数为16)以至其它任何进制整数。第11页/共103页122)小数部分的转换同样用一个简单例子说明十进制小数部分的转换方法。例如,B-1B-2B-1B-2要将一个十进制小数转换为二进制小数,实际上就是求B-1,B-2,给式(2.1.6)右侧乘以基数2得:(2.1.6)整数部分为B-1小数部分第12页/共103页13整数部分为1,此即为B-1。小数部分为12-1。小数部分再乘以基数2得:整数部分为1,此即为B-2。此时小数部分已为0,停止往下计算(若不为0,继续求B-3,B-4,直到小数部分为0或小数部分的位数满足一定精度时为止)。第13页/共103页14由以上分析可得到十进制小数部分转换为二进制小数的方法:小数部分乘以基数(2)取整数(0或1),先为高位(B-1)后为低位。显然,该方法也适用于将十进制小数转换为八进制小数(基数为8)、十六进制小数(基数为16)以至其它任何进制小数。第14页/共103页15例2.4将13.75转换为二进制数。分别将整数和小数部分进行转换:整数部分:13=1101B小数部分:0.75=0.11B因此,13.75=1101.11B第15页/共103页16例2.5将28.75转换为十六进制数整数部分:28=1CH小数部分:,B-1=CH,小数部分已为0,停止计算。因此,28.75=1C.CH第16页/共103页173二进制数与十六进制数之间的转换因为24=16,即可用四位二进制数表示一位十六进制数,所以可得到如下所述的二进制数与十六进制数之间的转换方法。将二进制数转换为十六进制数的方法:以小数点为界,向左(整数部分)每四位为一组,高位不足4位时补0;向右(小数部分)每四位为一组,低位不足4位时补0。然后分别用一个16进制数表示每一组中的4位二进制数。将十六进制数转换为二进制数的方法:直接将每一位十六进制数写成其对应的四位二进制数。第17页/共103页18例2.61101110.01011B=0110,1110.0101,1000B=6E.58H2F.1BH=101111.00011011B第18页/共103页192.1.3二进制数的运算1.二进制数的算术运算(1)加:0+0=00+1=11+0=11+1=0(进1)(2)减:0-0=01-1=01-0=10-1=1(借位)(3)乘:00=001=010=011=1(4)除:二进制除法是乘法的逆运算。第19页/共103页202.二进制数的逻辑运算(1)“与“运算(AND).“与”运算又称逻辑乘,可用符号“”或“”表示。运算规则如下:00=001=010=011=1可以看出,只有当两个变量均为“1”时,“与”的结果才为“1”。第20页/共103页21(2)“或”运算(OR)“或”运算又称逻辑加,可用符号“”或“+”表示。运算规则如下:00=001=110=111=1可以看出,两个变量只要有一个为“1”,“或”的结果就为“1”。第21页/共103页22(3)“非”运算(NOT)变量的“非”运算结果用表示。逻辑“非”运算规则如下:(4)“异或”运算(XOR)“异或”运算可用符号“”表示。运算规则如下:可以看出,两变量只要不同,“异或”运算的结果就为“1”。第22页/共103页23例2.7A=11110101B,B=00110000B,求解第23页/共103页242.2带符号数的表示及运算带符号数的表示及运算2.2.1机器数与真值日常生活中遇到的数,除了上述无符号数外,还有带符号数。对于带符号的二进制数,其正负符号如何表示呢?在计算机中,为了区别正数和负数,通常用二进制数的最高位表示数的符号。对于一个字节型二进制数来说,D7位为符号位,D6D0位为数值位。在符号位中,规定用“0”表示正,“1”表示负,而数值位表示该数的数值大小。把一个数及其符号位在机器中的一组二进制数表示形式,称为“机器数”。机器数所表示的值称为该机器数的“真值”。第24页/共103页252.2.2机器数的表示方法1.原码设数x的原码记作x原,如机器字长为n,则原码定义如下:在原码表示法中,最高位为符号位(正数为0,负数为1),其余数字位表示数的绝对值。第25页/共103页26例如,当机器字长n=8时,+0原=00000000B-0原=27+0(按定义计算,下同)=10000000B+8原=00001000B-8原=27+8=10001000B+127原=01111111B-127原=27+127=11111111B当机器字长n=16时,+0原=0000000000000000B-0原=215+0=1000000000000000B+8原=0000000000001000B-8原=215+8=1000000000001000B+32767原=0111111111111111B-32767原=215+32767=1111111111111111B第26页/共103页27可以看出,原码表示数的范围是。8位二进制原码表示数的范围为-127+127,16位二进制原码表示数的范围为-32767+32767;“0”的原码有两种表示法:00000000表示+0,10000000表示-0。第27页/共103页28原码表示法简单直观,且与真值的转换很方便,但不便于在计算机中进行加减运算。如进行两数相加,必须先判断两个数的符号是否相同。如果相同,则进行加法运算;如果不同,则进行减法运算。如进行两数相减,必须比较两数的绝对值大小,再由大数减小数,结果的符号要和绝对值大的数的符号一致。按上述运算方法设计的算术运算电路很复杂。因此,计算机中通常使用补码进行加减运算,这样就引入了反码表示法和补码表示法。第28页/共103页292.反码设数x的反码记作x反,如机器字长为n,则反码定义如下:正数的反码与其原码相同。例如,当机器字长n=8时:+0反=+0原=00000000B+127反=+127原=01111111B当机器字长n=16时:+8反=+8原=0000000000001000B+127反=+127原=0000000001111111B第29页/共103页30负数的反码是在原码基础上,符号位不变(仍为1),数值位按位取反。例如,当机器字长n=8时:-0反=(28-1)-0=11111111B-127反=(28-1)-127=10000000B反码表示数的范围是。8位二进制反码表示数的范围为-127+127,16位二进制反码表示数的范围为-32767+32767;“0”的反码有两种表示法:00000000表示+0,11111111表示-0。第30页/共103页313.补码设数x的补码记作x补,如机器字长为n,则补码定义如下:正数的补码与其原码、反码相同。例如,当机器字长n=8时:+8补=+8反=+8原=00001000B+127补=+127反=+127原=01111111B当机器字长n=16时:+8补=+8反=+8原=0000000000001000B+127补=+127反=+127原=0000000001111111B第31页/共103页32负数的补码是在原码基础上,符号位不变(仍为1),数值位按位取反,末位加1;或在反码基础上末位加1。例如,当机器字长n=8时:-8原=10001000B-127原=11111111B-8反=11110111B-127反=10000000B-8补=28-8=11111000B-127补=28-127=10000001B可以看出,补码表示数的范围是。8位二进制补码表示数的范围为-128+127,16位二进制反码表示数的范围为-32768+32767。8位二进制数的原码、反码和补码如表2.1所示。第32页/共103页33表2.18位二进制数的原码、反码和补码表00000000二进制数无符号十进制数带符号数原码反码补码000000010000001001111110011111111000000010000001111111011111111011111111012126127128129253254255+0+1+2+126+127-0-1-125-126-127+0+1+2+126+127-127-126-2-1-0+0+1+2+126+127-128-127-3-2-1第33页/共103页342.2.3真值与机器数之间的转换一原码转换为真值根据原码定义,将原码数值位各位按权展开求和,由符号位决定数的正负即可由原码求出真值。例2.8已知x原=00011111B,y原=10011101B,求x和yx=+(026+025+124+123+122+121+120)=31y=-(026+025+124+123+122+021+120)=-29第34页/共103页352.反码转换为真值要求反码的真值,只要先求出反码对应的原码,再按上述原码转换为真值的方法即可求出其真值。正数的原码是反码本身。负数的原码可在反码基础上,符号位仍为1不变,数值位按位取反。例2.9已知x反=00001111B,y反=11100101B,求x和y解x原=x反=00001111B,x=+(026+025+024+123+122+121+120)=15y原=10011010B,y=-(026+025+124+123+022+121+020)=-26第35页/共103页363.补码转换为真值同理,要求补码的真值,也要先求出补码对应的原码。正数的原码与补码相同。负数的原码可在补码基础上再次求补,即:第36页/共103页37例2.10已知x补=00001111B,y补=11100101B,求x和y解x原=x补=00001111B,x=+(026+025+024+123+122+121+120)=15y原=y补补=10011011B,y=-(026+025+124+123+022+121+120)=-27第37页/共103页382.2.4补码的加减运算1.补码加法在计算机中,凡是带符号数一律用补码表示,运算结果自然也是补码。其运算特点是:符号位和数值位一起参加运算,并且自动获得结果(包括符号位与数值位)。补码加法的运算规则为:即:两数补码的和等于两数和的补码。(2.2.5)第38页/共103页39例2.11已知+51补=00110011B,+66补=01000010B,-51补=11001101B,-66补=10111110B求+66补+51补=?+66补+-51补=?-66补+-51补=?解:(1)+66补+51补 二进制(补码)加法 十进制加法01000010+66补+66+)00110011+51补+)+5101110101+117补+117第39页/共103页40由于:+66补+51补=(+66)+(+55)补=01110101B结果为正,因此:(+66)+(+55)原=(+66)+(+55)补=01110101B其真值为+117,计算结果正确。(2)+66补+-51补 二进制(补码)加法 十进制加法01000010+66补+66+)1100110151补+)5100001111+15补+151自动丢失第40页/共103页41由于:+66补+51补=(+66)+(55)补=0000111B结果为正,因此:(+66)+(55)原=(+66)+(55)补=00001111其真值为+15,计算结果正确。(3)-66补+-51补 二进制(补码)加法 十进制加法10111110-66补-66+)1100110151补+)5110001011-117补-1171自动丢失第41页/共103页42由于66补+51补=10001011B=(66)+(55)补结果为负,因此(66)+(55)原=(66)+(55)补补=11110101B其真值为117,计算结果正确。可以看出,不论被加数、加数是正数还是负数,只要直接用它们的补码直接相加,当结果不超出补码所表示的范围时,计算结果便是正确的补码形式。但当计算结果超出补码表示范围时,结果就不正确了,这种情况称为溢出。第42页/共103页432.补码减法补码减法补码减法的运算规则为:(2.2.6)第43页/共103页44例例2.12已知+51补=00110011B,+66补=01000010B51补=11001101B,66补=10111110B求+66补+51补=?66补51补=?解+66补+51补=+66补+51补66补51补=66补+51补第44页/共103页45 二进制(补码)加法 十进制加法01000010+66补+66+)1100110151补-)+5100001111+15补+151自动丢失 二进制(补码)加法 十进制加法10111110-66补-66+)00110011+51补-)-5111110001-15补-15第45页/共103页46可以看出,无论被减数、减数是正数还是负数,上述补码减法的规则都是正确的。同样,由最高位向更高位的进位会自动丢失而不影响运算结果的正确性。计算机中带符号数用补码表示时有如下优点:可以将减法运算变为加法运算,因此可使用同一个运算器实现加法和减法运算,简化了电路。第46页/共103页47无符号数和带符号数的加法运算可以用同一个加法器实现,结果都是正确的。例如:无符号数带符号数1110000122531补+)00001101+)13+)+13补1110111023818补若两操作数为无符号数时,计算结果为无符号数11101110B,其真值为238,结果正确;若两操作数为补码形式,计算结果也为补码形式,11101110B为18的补码,结果也是正确的。第47页/共103页482.2.5溢出及其判断方法溢出及其判断方法1.进位与溢出所谓进位,是指运算结果的最高位向更高位的进位,用来判断无符号数运算结果是否超出了计算机所能表示的最大无符号数的范围。溢出是指带符号数的补码运算溢出,用来判断带符号数补码运算结果是否超出了补码所能表示的范围。例如,字长为n位的带符号数,它能表示的补码范围为2n1+2n11,如果运算结果超出此范围,就叫补码溢出,简称溢出。第48页/共103页492.溢出的判断方法判断溢出的方法很多,常见的有:通过参加运算的两个数的符号及运算结果的符号进行判断。单符号位法。该方法通过符号位和数值部分最高位的进位状态来判断结果是否溢出。双符号位法,又称为变形补码法。它是通过运算结果的两个符号位的状态来判断结果是否溢出。上述三种方法中,第种方法仅适用于手工运算时对结果是否溢出的判断,第和两种方法在计算机中都有使用。本节仅通过具体例子对第种方法做简要介绍。第49页/共103页50若符号位进位状态用CF来表示,当符号位向前有进位时,CF=1,否则,CF=0;数值部分最高位的进位状态用DF来表示,当该位向前有进位时,DF=1,否则,DF=0。单符号位法就是通过该两位进位状态的异或结果来判断是否溢出的。(2.2.7)若OF=1,说明结果溢出;若OF=0,则结果未溢出。也就是说,当符号位和数值部分最高位同时有进位或同时没有进位时,结果没有溢出,否则,结果溢出。第50页/共103页51例2.13设有两个操作数x=01000100B,y=01001000B,将这两个操作数送运算器做加法运算,试问:若为无符号数,计算结果是否正确?若为带符号补码数,计算结果是否溢出?解无符号数带符号数0100010068+68补+)01001000+)72+)+72补10001100140+140补DF=1CF=0第51页/共103页52若为无符号数,由于CF=0,说明结果未超出8位无符号数所能表达的数值范围(0255),计算结果10001100B为无符号数,其真值为140,计算结果正确。若为带符号数补码,由于CF=1,结果溢出;这里也可通过参加运算的两个数的符号及运算结果的符号进行判断,由于两操作数均为正数,而结果却为负数,因而结果溢出;+68和+72两数补码之和应为+140的补码,而8位带符号数补码所能表达的数值范围为128+127,结果超出该范围,因此结果是错误的。第52页/共103页53例2.14设有两个操作数x=11101110B,y=11001000B,将这两个操作数送运算器做加法运算,试问:若为无符号数,计算结果是否正确?若为带符号补码数,计算结果是否溢出?解无符号数带符号数11101110238-18补+)11001000+)200+)-56补10110110438-74补DF=1CF=01自动丢失第53页/共103页54若为无符号数,由于CF=1,说明结果超出8位无符号数所能表达的数值范围(0255)。两操作数11101110B和11001000B对应的无符号数分别为238和200,两数之和应为438255,因此,计算结果是错误的。若为带符号数补码,由于CF=0,结果未溢出。两操作数11101110B和11001000B分别为18和56的补码,其结果应为74的补码形式,而计算结果10110110B正是74的补码,因此结果正确。第54页/共103页552.3信息的编码2.3.1二进制编码的十进制数编码二进制编码的十进制数编码(BCD编码编码)虽然二进制数对计算机来说是最佳的数制,但是人们却不习惯使用它。为了解决这一矛盾,人们提出了一个比较适合于十进制系统的二进制编码的特殊形式,即将1位十进制的09这10个数字分别用4位二进制码的组合来表示,在此基础上可按位对任意十进制数进行编码。这就是二进制编码的十进制数,简称BCD码(Binary-CodedDecimal)。第55页/共103页564位二进制数码有16种组合(00001111),原则上可任选其中的10个来分别代表十进制中09这10个数字。但为了便于记忆,最常用的是8421BCD码,这种编码从00001111这16种组合中选择前10个即00001001来分别代表十进制数码09,8、4、2、1分别是这种编码从高位到低位每位的权值。BCD码有两种形式,即压缩型BCD码和非压缩型BCD码。第56页/共103页571压缩型BCD码压缩型BCD码用一个字节表示两位十进制数。例如,10000110B表示十进制数86。2非压缩型BCD码非压缩型BCD码用一个字节表示一位十进制数。高4位总是0000,低4位用00001001中的一种组合来表示09中的某一个十进制数。第57页/共103页58表2.28421BCD码部分编码表十进制数压缩型BCD码非压缩型BCD码123910111920210000000100000010000000110000100100010000000100010001100100100000001000010000000100000010000000110000100100000001000000000000000100000001000000010000100100000010000000000000001000000001第58页/共103页59需要说明的是,虽然BCD码可以简化人机联系,但它比纯二进制编码效率低,对同一个给定的十进制数,用BCD码表示时需要的位数比用纯二进制码多,而且用BCD码进行运算所花的时间也要更多,计算过程更复杂,因为BCD码是将每个十进制数用一组4位二进制数来表示,若将这种BCD码送计算机进行运算,由于计算机总是将数当作二进制数来运算,所以结果可能出错,因此需要对计算结果进行必要的修正,才能使结果为正确的BCD码形式。详见本小节例2.17。第59页/共103页60例2.15十进制数与BCD数相互转换。将十进制数69.81转换为压缩型BCD数:69.81=(01101001.10000001)BCD将BCD数10001001.01101001转换为十进制数:(10001001.01101001)BCD=89.69第60页/共103页61例2.16设有变量x等于10010110B,当该变量分别为无符号数、原码、补码、压缩型BCD码时,试分别计算变量x所代表的数值大小。解无符号数:x=10010110B=127+026+025+124+023+122+121+020=150原码:x原=10010110Bx=026+025+124+023+122+121+020=22补码:x补=10010110Bx原=x补补=11101010Bx=126+125+024+123+022+121+020=106BCD码:xBCD=10010110Bx=96第61页/共103页62例2.17(BCD码运算时的修正问题)用BCD码求38+49。解0011100038的BCD码+)0100100149的BCD码1000000181的BCD码计算结果10000001是81的BCD数,而正确结果应为87的BCD数10000111,因此结果是错误的。其原因是,十进制数相加应该是“逢十进一”,而计算机按二进制数运算,每4位为一组,低4位向高4位进位与十六进制数低位向高位进位的情况相当,是“逢十六进一”,所以当相加结果超过9时将比正确结果少6,因此结果出错。解决办法是对二进制加法运算结果采用“加6修正”,从而将二进制加法运算的结果修正为BCD码加法运算结果。BCD数相加时,对二进制加法运算结果修正的规则如下:第62页/共103页63如果两个对应位BCD数相加的结果向高位无进位,且结果小于或等于9,则该位不需要修正;若得到的结果大于9而小于16,则该位需要加6修正。如果两个对应位BCD数相加的结果向高位有进位(结果大于或等于16),则该位需要进行加6修正。因此,两个BCD数进行运算时,首先按二进制数进行运算,然后必须用相应的调整指令进行调整,从而得到正确的BCD码结果。有关BCD运算结果的调整指令将在第4章“80 x86指令系统”中介绍。第63页/共103页642.3.2ASCII字符编码字符编码所谓字符,是指数字、字母以及其他一些符号的总称。现代计算机不仅用于处理数值领域的问题,而且要处理大量的非数值领域的问题。这样一来,必然需要计算机能对数字、字母、文字以及其他一些符号进行识别和处理,而计算机只能处理二进制数,因此,通过输入/输出设备进行人机交换信息时使用的各种字符也必须按某种规则,用二进制数码0和1来编码,计算机才能进行识别与处理。第64页/共103页65目前,国际上使用的字符编码系统有许多种。在微机、通信设备和仪器仪表中广泛使用的是ASCII码(AmericanStandardCodeforInformationInterchange)美国标准信息交换码。ASCII码用一个字节来表示一个字符,采用7位二进制代码来对字符进行编码,最高位一般用做校验位。7位ASCII码能表示27=128种不同的字符,其中包括数码(09),英文大、小写字母,标点符号及控制字符等,见表2.3。该表的使用方法读者应熟练掌握。如数字“1”的ASCII码值为31H,字母“A”的ASCII码值为41H,符号“?”的ASCII码值为3FH等。第65页/共103页66表2.3美国标准信息交换码ASCII(7位代码)第66页/共103页672.4数的定点与浮点表示法2.4.1定点表示定点表示所谓定点表示法,是指小数点在数中的位置是固定的。原理上讲,小数点的位置固定在哪一位都是可以的,但通常将数据表示成纯小数或纯整数形式,如图2.1所示。图2.1定点数的两种表示方法(a)纯小数形式;(b)纯整数形式第67页/共103页68设用一个n+1位字来表示一个数x,其中一位表示符号位(0表示正,1表示负),其他n位为数值位。对于纯小数表示法,所能表示的数x(原码表示,下同)的范围为:(12n)x12n(2.4.1)它能表示的数的最大绝对值为12n,最小绝对值为2n。对于纯整数表示法,所能表示的数x的范围为:(2n1)x2n1(2.4.2)它能表示的数的最大绝对值为2n1,最小绝对值为1。第68页/共103页69定点表示法存在的问题:因为实际工作中很少遇到数据都是纯小数或纯整数的情况,所以定点表示法要求程序员做的一件重要工作是为要计算的问题选择“比例因子”。所有原始数据都要用比例因子化成纯小数或纯整数形式,计算结果又要用比例因子恢复实际值。这一过程不仅占用资源,有时为了选择适当的比例因子以免结果溢出,需要反复多次调整比例因子,而且比例因子也需要占用一定的存储空间。第69页/共103页702.4.2浮点表示浮点表示所谓浮点表示法,就是小数点在数中的位置是浮动的。任意一个二进制数x总可以写成如下形式:(2.4.3)其中,d称为尾数,是二进制纯小数,指明数的全部有效数字,前面的符号称为数符,表示数的符号,用尾数前的一位表示,该位为0,表明该浮点数为正,该位为1,表明该浮点数为负;p称为阶码,它前面的符号称为阶符,用阶码前一位表示,阶码为正时,用0表示,阶码为负时,用1表示。浮点数的编码格式如图所示。第70页/共103页71可以看出,将尾数d的小数点向右(阶码p为正时)或向左(阶码p为负时)移动p位,即可得到该浮点数表示的数值x。阶码p指明小数点的位置,小数点随着阶码的大小和正负而浮动,因此把这种数称为浮点数。设阶码的位数为m位,尾数的位数为n位,则该浮点数表示的数值范围为:(2.4.4)在字长相同的情况下,浮点数能表示的数值范围比定点数大得多,且精度高,但浮点运算规则复杂。第71页/共103页72例.1100.11的浮点数表示是0.11001124解:尾数为110011,数符为0;阶码为3bit(100),阶符为0。小数点每左移1位,则阶码p加1;小数点每右移1位,则阶码p减1。例:设浮点数的阶码部分3bit,其中阶码为2bit,阶符为1bit;尾数部分为5bit,其中尾符为1bit,尾数为4bit。若此数表示为-2313D,其二进制表示为211(-1101),则在计算机中相应的表示形式如下:01111101第72页/共103页73小小结结一、进位计数制及其表示方法一、进位计数制及其表示方法(一)、进位计数制及其要素:(一)、进位计数制及其要素:进位计数制:按进位原则进行计数的方法。进位计数制:按进位原则进行计数的方法。例:十进制数有例:十进制数有:0、1、2、3、4、5、6、7、8、9十种状态。十种状态。我们说:我们说:十进制数基数十进制数基数10,变化范围,变化范围0(10-1),逢十进一。逢十进一。看一个十进制数:看一个十进制数:4094每一位十种数码的状态每一位十种数码的状态(09)千千百百十十个个本位绝对值的大小本位绝对值的大小=数数位权位权103102101100如:千位如:千位=4103=4000第73页/共103页74十进制数有二个要素:十进制数有二个要素:1.基数:十基数:十每一位每一位0、1、2、3、4、5、6、7、8、10-1(逢(逢十十进进一)。一)。2.位权:位权:10i某一位数绝对值大小某一位数绝对值大小=数数位权位权.二个要素二个要素:适用于二、八、十六进制。适用于二、八、十六进制。二进制数:基数二进制数:基数2位权位权2i八进制数:基数八进制数:基数8位权位权8i十六进制数十六进制数:基数基数16位权位权16i第74页/共103页75(二)、(二)、进位计数制的表示方法:进位计数制的表示方法:123456=1 103+2 102+3 101+4 100+5 10-1+6 10-2推广到一般形式(任意十进制)推广到一般形式(任意十进制):N=kn 10n+kn-1 10n-1+k0 100+k-1 10-1+k-m 10-m=ki 10i(i=-mn)任何某一位数大小任何某一位数大小=ki 10i对于任意进制对于任意进制:N=ki Ri(i=-mn)R基数基数,逢逢R进一进一.Ri位位权权第75页/共103页76例如:二进制数例如:二进制数B=10011101B=1 27+1 24+1 23+1 22+1 20=(157)10在计算机里进行运算和处理均是按在计算机里进行运算和处理均是按二进制数二进制数处理的。处理的。而二进制数写起来麻烦而二进制数写起来麻烦;书写时又以书写时又以八进制或十六进制八进制或十六进制表示;表示;日常生活中又常用日常生活中又常用十进制十进制,因此就有:因此就有:二二十十八八十十二二八八数制之间转换问题数制之间转换问题十六十六十十二二十六十六第76页/共103页77二、二、数制之间的转换:数制之间的转换:(一)、(一)、十十二二1.整数整数十十二二(除(除2取余法,降幂法)取余法,降幂法)(1)除除2取余法取余法(217)10=kn 2n+kn-1 2n-1+k1 21+k0 20=2(kn 2n-1+kn-1 2n-2+k1 20)+k02(kn 2n-1+kn-1 2n-2+k1 20)是是2的倍的倍数数k0是余数是余数.第77页/共103页78(217)102-得到余数得到余数k0/2整数整数商商 余数:余数:按照相反的方向写下来。按照相反的方向写下来。/2/2/2/2/2/2/2/22171085427136310-商商 10011011余数余数(217)10=(11011001)2书写方向书写方向第78页/共103页79结论结论:整数除整数除2 2取余,直到商为取余,直到商为0 0为止,为止,读数由后向前。适用于数值比较小的情况。(2)降幂法:计算(217)10=(11011001)2权值:2102928272625242322212010245122561286432168421217-27=89 a7=1,9-23=1a3=189-26=25a6=1,a2=0a5=0,a1=025-24=9a4=1,1-20=0a0=1第79页/共103页802.小数十二:乘2取整方法:对十进制数逐次乘2,小数点前边系数为系数ki。即乘2取整法,位数取决于要求精度。如:(0.613)10 2=1.226k-1=1(0.226)10 2=0.452k-2=0(0.452)10 2=0.904k-3=0(0.904)10 2=1.808k-4=1(0.1001)2=(0.5625)10(0.808)10 2=1.616k-5=1(0.10011)2=(0.609375)10(0.616)10 2=1.232k-6=1(0.613)10=(0.1001)2k-7=0第80页/共103页813.二十同样可以用公式进行(0.1001)2=1 2-1+1 2-4=0.5+0.0625=(0.5625)10(0.10011)2=1 2-1+1 2-4+1 2-5+1 2-6=(0.609375)10看一下常用的几种数制写法:八位二进制数第81页/共103页82十进制十进制二进制二进制八进制八进制十六进制十六进制BCD00000111112102210311331141004410051015510161106611071117711181000108100091001119100110101012A1000011101113B1000112110014C1001013110115D1001114111016E1010015111117F101011610000201010110.11.12.(255)D11111111B377QFFH(10,0101,0101)BCD第82页/共103页83(二)、二八,二十六,二BCD之间转换1、二八二八:以小数点为界向左向右三位一段,不够补0,三位二进制数用一位八进制数表示。例:(1,101,001.010,011,1)2 不够补0 不够补0(001101001.010011100)2=(151.234)8八二:一位八进制数用三位二进制数表示.(151234)8=(001101001.010011100)2第83页/共103页842、二、二十六:十六:二二十六:十六:以小数点为界向左向右四位一段,以小数点为界向左向右四位一段,不够补不够补0,四位二进制数用一位十六进制数表示。四位二进制数用一位十六进制数表示。例:(例:(1101001.0100111)2(69.4E)16 不够补不够补0 不够补不够补0(0110,1001.0100,1110)2=(69.4E)16十六十六二:二:一位十六进制数用四位二进制数表示。一位十六进制数用四位二进制数表示。例:例:(69.4E)16=(0110,1001.0100,1110)2第84页/共103页853、二二BCDBCD数:数:常用常用8421码,每一位码,每一位十进制数十进制数用用四位二进制编码表示。四位二进制编码表示。1111B9D1001BCD10D00010000BCDBCD码与二进制数之间转换没有直接关系,码与二进制数之间转换没有直接关系,必须先转换成十进制必须先转换成十进制,然后转换成二进制。然后转换成二进制。例:例:1111111B=255D=0010,0101,0101B