第1章 数字与编码_第1页
第1章 数字与编码_第2页
第1章 数字与编码_第3页
第1章 数字与编码_第4页
第1章 数字与编码_第5页
已阅读5页,还剩34页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、第第1 1章章数数制与编码制与编码 本章主要内容本章主要内容(1) 进位记数制进位记数制(2)不同进位制数之间的转换不同进位制数之间的转换(3) 二进制数的算术运算和逻辑运算二进制数的算术运算和逻辑运算(4)数据在计算机中的表示形式数据在计算机中的表示形式(5) 字符编码字符编码1.1 进位记数制进位记数制n计算机中全部信息(包括指令和数据)都是采用二进制数,计算机中全部信息(包括指令和数据)都是采用二进制数,为了书写方便,又经常采用十六进制。人们在日常生活中又为了书写方便,又经常采用十六进制。人们在日常生活中又广泛采用十进制。广泛采用十进制。n二进制、十六进制、十进制都是进位记数制。二进制、

2、十六进制、十进制都是进位记数制。1.1.1 进位记数制及其基数和权进位记数制及其基数和权n进位记数制:用一组固定的数字符号和特定的规则表进位记数制:用一组固定的数字符号和特定的规则表示数的方法。示数的方法。l基数和权基数和权l在进位记数制中,一种进位制所允许选用的基本数在进位记数制中,一种进位制所允许选用的基本数字符号的个数称为这种进位制的字符号的个数称为这种进位制的基数基数。l同一个数字符号处在不同的数位时,它所代表的数同一个数字符号处在不同的数位时,它所代表的数值是不同的,每个数字符号所代表的数值等于它本值是不同的,每个数字符号所代表的数值等于它本身乘以一个与它所在数位对应的常数,这个常数

3、叫身乘以一个与它所在数位对应的常数,这个常数叫做位权,简称做位权,简称权权(weight)。)。n不同进位制的基数不同不同进位制的基数不同 十进制:基数十进制:基数10,数字符号,数字符号09 二进制:基数二进制:基数2,数值符号,数值符号0,1n同一进制,不同数位其权值不同。同一进制,不同数位其权值不同。1.1.2 几种常用的进位记数制几种常用的进位记数制1. 十进制十进制任何一个十进制数,都可以用一个多项式来表示:任何一个十进制数,都可以用一个多项式来表示:等式右边的表示形式,称为十进制数的等式右边的表示形式,称为十进制数的多项式表示法,多项式表示法,也叫按权展开式也叫按权展开式;等号左边

4、的形式,称为十进制的位置记数法。位置记等号左边的形式,称为十进制的位置记数法。位置记数法是一种与位置有关的表示方法,同一个数字符号数法是一种与位置有关的表示方法,同一个数字符号处于不同的数位时,所代表的数值不同,即其权值不处于不同的数位时,所代表的数值不同,即其权值不同。同。21012312.253 101 102 102 105 10 2. 二进制二进制二进制数的基数为二进制数的基数为2,即它所用的数字符号个数只有两,即它所用的数字符号个数只有两个(个(“0”和和“1”)。它的计数进位规则为)。它的计数进位规则为“逢二进一逢二进一”。二进制数只有两种数字符号,因而便于数字系统与电二进制数只有

5、两种数字符号,因而便于数字系统与电子计算机内部的表示与存储。子计算机内部的表示与存储。它的另一个优点是运算规则的简便性,而运算规则的简它的另一个优点是运算规则的简便性,而运算规则的简单,必然导致运算电路的简单以及相关控制的简化单,必然导致运算电路的简单以及相关控制的简化 。 3. 八进制八进制 八进制数的基数八进制数的基数R8,每位可能取八个不同的数字符,每位可能取八个不同的数字符号号07中的任何一个,进位规则是中的任何一个,进位规则是“逢八进一逢八进一”。l1位八进制对应位八进制对应3位二进制位二进制l八进制:八进制: 0, 1, 2, 3, 4, 5, 6, 7l二进制:二进制:000,0

6、01,010,011,100,101,110,1114. 十六进制十六进制十六进制数的基数十六进制数的基数R16,每位用十六个数字符号,每位用十六个数字符号0、1、2、3、4、5、6、7、8、9、A、B、C、D、E、F中的一中的一个表示,进位规则是个表示,进位规则是“逢十六进一逢十六进一”。 与二进制转换时候,其每位对应与二进制转换时候,其每位对应4位二进制数。位二进制数。在编程时,为了书写方便,常用十六进制表示。在编程时,为了书写方便,常用十六进制表示。1.2 不同进位制数之间的转换不同进位制数之间的转换1.2.1 二进制数转换为十进制数二进制数转换为十进制数u按权展开,例如按权展开,例如(

7、101015.101)2 (252321202-12-3)10 (328210.50.125)10 (43.625)10u同样的方法也可将八进制数转换为十进制数。同样的方法也可将八进制数转换为十进制数。p这种用以实现数制转换的方法,称为多项式替代法。这种用以实现数制转换的方法,称为多项式替代法。 1.2.2 十进制数转换为二进制数十进制数转换为二进制数1. 十进制整数转换为二进制整数十进制整数转换为二进制整数 除除2取余,例如十进制数取余,例如十进制数29的转换。的转换。 2 921 4余数1 (B0 ) 72232120余数0 (B1 )余数1 (B2 )余数1 (B3 )余数1 (B4 )

8、 29D=11101B n采用采用“除除8取余取余”或或“除除16取余取余”的方法,即可将一个的方法,即可将一个十进制整数转换为八进制整数或十六进制整数。十进制整数转换为八进制整数或十六进制整数。n这种数制转换的方法称为基数除法或这种数制转换的方法称为基数除法或“除基取余除基取余”法。法。可概括为:可概括为:“除基取余,直至商为除基取余,直至商为0,注意确定高、低,注意确定高、低位位”。2. 十进制小数转换为二进制小数十进制小数转换为二进制小数 乘乘2取整取整 例例 把把0.625转换成二进制数转换成二进制数 把把0.625乘乘2取整取整0.625 21.250B-1=1 0.25 2 0.5

9、0B-2=00. 5 2 1.0B-3=1 0.625=0.101Bn在十进制小数转换成二进制小数时,整个计算过程可能在十进制小数转换成二进制小数时,整个计算过程可能无限地进行下去,这时,一般考虑到计算机实际字长的无限地进行下去,这时,一般考虑到计算机实际字长的限制,只取有限位数的近似值就可以了。限制,只取有限位数的近似值就可以了。 n上述这种数制转换方法称为基数乘法或上述这种数制转换方法称为基数乘法或“乘基取整乘基取整”法。法。可概括如下:可概括如下:“乘基取整,注意确定高、低位及有效位乘基取整,注意确定高、低位及有效位数。数。”u如果一个数既有整数部分又有小数部分,则用前述如果一个数既有整

10、数部分又有小数部分,则用前述的的“除基取余除基取余”及及“乘基取整乘基取整” 结合求解。结合求解。1.2.3 任意两种进位制数之间的转换任意两种进位制数之间的转换 n为实现任意两种进位制数之间的转换(为实现任意两种进位制数之间的转换(例如从例如从P进制转进制转换成换成R进制进制),可以用),可以用“基数乘除法基数乘除法”或或“多项式替多项式替代法代法”直接从直接从P进制转换成进制转换成R进制,此时如果熟悉进制,此时如果熟悉P进进制的运算规则就可以采用制的运算规则就可以采用“基数乘除法基数乘除法”;如果熟悉;如果熟悉R进制的运算规则就采用进制的运算规则就采用“多项式替代法多项式替代法”。n有时可

11、能对有时可能对P进制与进制与R进制的运算规则都不熟悉,那么进制的运算规则都不熟悉,那么一种方便的方法就是利用十进制作桥梁。一种方便的方法就是利用十进制作桥梁。n首先将其转换为十进制,这里采用首先将其转换为十进制,这里采用“多项式替代法多项式替代法”;然后将十进制转换为所需目标进制,这里采用然后将十进制转换为所需目标进制,这里采用“基数基数乘除法乘除法”。1.3 二进制数的算术运算与逻辑运算二进制数的算术运算与逻辑运算1.3.1 二进制数的算术运算二进制数的算术运算n加法运算规则:逢二进一加法运算规则:逢二进一n减法运算规则:借一当二减法运算规则:借一当二n乘法运算规则:乘法运算规则:000,

12、010 , 100 ,111 例如:例如:1101x1010=1101110二进制的乘法可以归结为:二进制的乘法可以归结为:“加加”和和“移位移位”。n除法运算:乘法的逆运算。除法运算:乘法的逆运算。 以二进制的乘法及减法规则实现。以二进制的乘法及减法规则实现。1.3.2 二进制数的逻辑运算二进制数的逻辑运算n逻辑运算与算术运算有着本质上的差别,它是按位进行的,逻辑运算与算术运算有着本质上的差别,它是按位进行的,其运算的对象及运算结果只能是其运算的对象及运算结果只能是0和和1这样的逻辑量。这样的逻辑量。n这里的这里的0和和1并不具有数值大小的意义,而仅仅具有如并不具有数值大小的意义,而仅仅具有

13、如“真真”和和“假假”、“是是”和和“非非”这样的逻辑意义。这样的逻辑意义。n二进制数的逻辑运算实际上是将二进制数的每一位都看成逻二进制数的逻辑运算实际上是将二进制数的每一位都看成逻辑量时进行的运算。辑量时进行的运算。n基本的逻辑运算有基本的逻辑运算有逻辑逻辑“或或”、逻辑、逻辑“与与”和逻辑和逻辑“非非”三三种,常用的还有种,常用的还有逻辑逻辑“异或异或”运算。运算。n有关逻辑运算的具体运算规则将在有关逻辑运算的具体运算规则将在2.1.2节中予以说明。节中予以说明。1.3.3 移位运算移位运算1.1.逻辑移位逻辑移位n逻辑左移:逻辑左移: 将操作数的所有位同时左移,最高位移出原操作数之外,将

14、操作数的所有位同时左移,最高位移出原操作数之外,最低位补最低位补0。逻辑左移一位相当于无符号数乘。逻辑左移一位相当于无符号数乘2。 例如,将例如,将01100101逻辑左移一位后变成逻辑左移一位后变成11001010,相当于,相当于 (101)102202 。 n逻辑右移:逻辑右移: 将操作数的所有位同时右移,最低位移出原操作数之外,将操作数的所有位同时右移,最低位移出原操作数之外,最高位补最高位补0。逻辑右移一位相当于将无符号数除以。逻辑右移一位相当于将无符号数除以2。例如,。例如,将将10010100逻辑右移一位后变成逻辑右移一位后变成01001010,相当于,相当于148274 。n循环

15、左移:循环左移:将操作数的所有位同时左移,并将移出的将操作数的所有位同时左移,并将移出的最高位送到最低位。循环左移的结果不会丢失被移动最高位送到最低位。循环左移的结果不会丢失被移动的数据位。的数据位。例如,将例如,将10010100循环左移一位后变成循环左移一位后变成00101001。n循环右移循环右移:将操作数的所有位同时右移,并将移出的:将操作数的所有位同时右移,并将移出的最低位送到最高位。它也不会丢失被移动的数据位。最低位送到最高位。它也不会丢失被移动的数据位。例如,将例如,将10010100循环右移一位后变成循环右移一位后变成01001010。2. 算术移位算术移位 算术移位是把操作数

16、当作带符号数进行移位,所以在算术移位是把操作数当作带符号数进行移位,所以在算术移位中,必须保持符号位不变算术移位中,必须保持符号位不变。否则将发生溢出。否则将发生溢出。 与逻辑移位类似,算术移位可分为与逻辑移位类似,算术移位可分为算术左移、算术右算术左移、算术右移、循环左移和循环右移移、循环左移和循环右移。循环左移和循环右移的操作。循环左移和循环右移的操作与前述逻辑移位时的情况相同,都是不丢失移出原操作与前述逻辑移位时的情况相同,都是不丢失移出原操作数的位,而将其返回到操作数的另一端。数的位,而将其返回到操作数的另一端。1.4 数据在计算机中的表示形式数据在计算机中的表示形式电子计算机实质上是

17、一个二进制的数字系统,在机器电子计算机实质上是一个二进制的数字系统,在机器内部,二进制数总是存放在由具有两种相反状态的存储内部,二进制数总是存放在由具有两种相反状态的存储元件构成的寄存器或存储单元中,即二进制数码元件构成的寄存器或存储单元中,即二进制数码0和和1是是由存储元件的两种相反状态来表示的。由存储元件的两种相反状态来表示的。另外,对于数的符号另外,对于数的符号(正号(正号“”和负号和负号“”)也只能也只能用这两种相反的状态来区别。也就是说,只能用用这两种相反的状态来区别。也就是说,只能用0或或1来来表示。表示。1.4.1 机器数与真值机器数与真值n例例1. 正二进制数正二进制数N1=+

18、1011001,在计算机中可表示为:在计算机中可表示为:01011001符号位数值位 例例2. 负二进制数负二进制数N1=-1011001,在计算机中可表示为:在计算机中可表示为:11011001符号位数值位定义:一个数(连同符号)在机器中加以数码化后的表示形式,定义:一个数(连同符号)在机器中加以数码化后的表示形式,称为称为机器数机器数;而把机器数所代表的实际值称为机器数的;而把机器数所代表的实际值称为机器数的真值真值。1.4.2 常见的机器数形式常见的机器数形式 1. 原码原码 数码序列中的最高位为符号位,符号位为数码序列中的最高位为符号位,符号位为0表示该数为表示该数为正数,为正数,为1

19、表示该数为负数;其余有效数值部分则用二表示该数为负数;其余有效数值部分则用二进制的绝对值表示。进制的绝对值表示。 例如:例如:真值x x原 0.1001 0.1001 0.1001 1.1001 1001 01001 1001 11001n0 的原码有两种表示,的原码有两种表示,以定点小数为例以定点小数为例 + 0原原= 0.000 0000 0原原= 1.000 0000 原码表示简单直观,但运算时符号位与数值位要区原码表示简单直观,但运算时符号位与数值位要区别对待,别对待,在原码表示中,符号位不是数值的一部分,在原码表示中,符号位不是数值的一部分,它们仅是人为约定(它们仅是人为约定(“0为

20、正,为正,1为负为负”),所以符号位),所以符号位在运算过程中需要单独处理,不能当作数值的一部分在运算过程中需要单独处理,不能当作数值的一部分直接参与运算直接参与运算。 2.补码补码定点小数补码定义如下:定点小数补码定义如下: 若定点小数的补码序列为若定点小数的补码序列为X0 . X1Xn ,则,则式中,式中,x 代表真值,代表真值, 为补码表示的机器数为补码表示的机器数。 若定点整数的补码序列为若定点整数的补码序列为 ,则,则u正数的补码是其自身;负数的补码是用模数加上该负数。正数的补码是其自身;负数的补码是用模数加上该负数。0的补码只有一种表示;的补码只有一种表示;u从原码转换为补码的变化

21、规律为:从原码转换为补码的变化规律为:“符号位保持不变(仍为符号位保持不变(仍为1),其他各位求反,然后末位加),其他各位求反,然后末位加1”,简称,简称“求反加求反加1”。 例例 x0.1010,则,则x原原0.1010,x补补0.1010 x0.1010,则,则x原原1.1010,x补补1.0110 容易看出,当容易看出,当x0时,若把时,若把x补补除符号位外除符号位外“求反加求反加1”,即,即可得到可得到x原原。也就是说,对一个补码表示的数,再次求补。也就是说,对一个补码表示的数,再次求补,可得该数的原码。,可得该数的原码。3.反码反码定点小数反码定义如下:定点小数反码定义如下: 若定点

22、小数的若定点小数的反反码序列为码序列为X0 . X1Xn ,则则式中,式中,x代表真值代表真值,x反反为补码表示的机器数为补码表示的机器数。 若定点整数的补码序列为若定点整数的补码序列为 ,则,则u反码与原码相比,两者的符号位一样。即对于正数,符反码与原码相比,两者的符号位一样。即对于正数,符号位为号位为0;对于负数,符号位为;对于负数,符号位为1。在数值部分,对于正。在数值部分,对于正数,反码的数值部分与原码按位相同;对于负数,反码数,反码的数值部分与原码按位相同;对于负数,反码的数值部分是原码的按位求反。的数值部分是原码的按位求反。u 0的反码有两种表示,分别为全的反码有两种表示,分别为全

23、0或者全或者全1。 u由原码表示容易得到相应的反码表示。例如:由原码表示容易得到相应的反码表示。例如: x0.1001,x原原0.1001,x反反0.1001 x0.1001,x原原1.1001,x反反1.0110n原码、反码、补码之间的转换原码、反码、补码之间的转换 转换规则如下图所示:转换规则如下图所示:4. 移码移码 设定点整数移码形式为设定点整数移码形式为 ,则,则 其中其中 式中式中x为真值,为真值,x移移为其移码。为其移码。u把真值把真值x在数轴上向正方向平移在数轴上向正方向平移 单位,移码由此得名。单位,移码由此得名。又叫增码。又叫增码。u移码特点:移码特点: 1)移码是把真值映

24、射到一个正数域,因此移码的大小移码是把真值映射到一个正数域,因此移码的大小可以直观地反映真值的大小。无论是正数还是负数,可以直观地反映真值的大小。无论是正数还是负数,用移码表示后,可以按无符号数比较大小。用移码表示后,可以按无符号数比较大小。 2)移码的数值部分与相应的补码各位相同,而符号位移码的数值部分与相应的补码各位相同,而符号位与补码相反。在移码中符号位为与补码相反。在移码中符号位为0表示真值为负数,符表示真值为负数,符号位为号位为1表示真值为正数。表示真值为正数。 3)移码为全移码为全0时,它对应的真值最小时,它对应的真值最小。 4)真值真值0在移码中的表示是唯一的,即:在移码中的表示

25、是唯一的,即: 02000010000n移四种机器数的比较和小结四种机器数的比较和小结 原码、补码、反码和移码均是计算机能识别的机器数,原码、补码、反码和移码均是计算机能识别的机器数,机器数与真值不同,它是一个数(连同符号)在计算机机器数与真值不同,它是一个数(连同符号)在计算机中加以数码化后的表示形式。中加以数码化后的表示形式。 正数的原码、补码和反码的表示形式相同,负数的原码正数的原码、补码和反码的表示形式相同,负数的原码、补码和反码各有不同的定义,它们的表示形式不同,、补码和反码各有不同的定义,它们的表示形式不同,相互之间可依据特定的规则进行转换。相互之间可依据特定的规则进行转换。 四种

26、机器数形式的最高位均为符号位。原码、补码和四种机器数形式的最高位均为符号位。原码、补码和反码表示中,为反码表示中,为0表示正数,为表示正数,为1表示负数;在移码表表示负数;在移码表示中,为示中,为0表示负数,为表示负数,为1表示正数。表示正数。 原码、补码和反码既可用来表示浮点数中的尾数,又原码、补码和反码既可用来表示浮点数中的尾数,又可用来表示其阶码;而移码则主要用来表示阶码。可用来表示其阶码;而移码则主要用来表示阶码。 0在补码和移码表示中都是唯一的,在补码和移码表示中都是唯一的,0在原码和反码表在原码和反码表示中都有两种不同的表示形式。示中都有两种不同的表示形式。1.4.3 二二-十进制编码十进制编码n用几位二进制码来表示一位十进制数的方法称为十进用几位二进制码来表示一位十进制数的方法称为十进制数的二进制编码,简称制数的二进制编码,简称BCD码码(Binary Code Decimal)。n常见的常见的BCD码有码有8421码、余码、余3码、格雷码等。平常说到码、格雷码等。平常说到BCD码,通常指的是码,通常指的是8421码。码。1. 有权码和无权码的概念有权码和无权码的概念n有权码:有权码:代码中的各位有固定的权值(如代码中的各位有固定的权值(如8421码)。码)。n无权

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论