单片机控制技术及应用
上QQ阅读APP看书,第一时间看更新

1.3 计算机中数的表示形式

在现代微型机中,其内部运算器通常由一个补码加法器、n位寄存器/计数器组和移位控制电路等组成,但它恰能进行各种算术运算和逻辑操作。这就是说,补码加法器既能做加法又能将减法运算变为加法来做,从而大大简化了运算器内部的电路设计。这应归功于人们长期以来对计算机中码制的研究。

机器数是指数的符号和值均采用二进制的表示形式。因此,机器数在定点和浮点机中的表示形式各不相同。为了方便起见,这里的机器数均指在定点整数机中的表示形式。即最高位是符号位(0表示正数,1表示负数),其余位为数值位,小数点约定在数值位之后。在计算机中,机器数有原码、反码、补码、变形原码、变形反码、变形补码和移码等多种形式。

1.3.1 机器数的原码、反码和补码

原码、反码和补码是机器数的三种基本形式,它和机器数的真值不同。机器数的真值定义为采用+和-表示的二进制数符号,并非是真正的机器数。例如,+76的机器数真值为+1001100B,原码形式为01001100B(最高位的0表示正数);-76的真值为-1001100B,原码为11001100B(最高位的1表示负数)。

1.原码

原码表示法是机器数的一种简单的表示法。这种表示法数的最高位为符号位(用0或1来表示),其余位为数值位,符号位的0表示该数为正数,符号位为1表示它是负数。通常,一个数的原码可以先把该数用方括号括起来,并在方括号右下角加个“原”字来标记。设有一数为x,则原码表示可记作[x]

【例1-6】 设X1=+1100B,X2=-1100B,请分别写出它们在8位微机中的原码。

解:其原码记为

[X1]=[00001100]

[X2]=[10001100]

原码表示数的范围与二进制位数有关。当用8位二进制来表示小数原码时,其表示范围为

最大值为0.1111111,其真值约为(0.99)D

最小值为1.1111111,其真值约为(-0.99)D

当用8位二进制来表示整数原码时,其表示范围为

最大值为01111111,其真值为(127)D

最小值为11111111,其真值为(-127)D

在原码表示法中,对0有两种表示形式:

[+0]=00000000

[-0]=10000000

2.反码

在微型计算机中,二进制数的反码可由原码得到,有正数的反码和负数的反码之分:正数的反码和原码相同;负数反码的符号位和负数原码的符号位相同,数值位是它的数值位的按位取反。反码的标记方法和原码类似,只要在被括数方括号的右下角添加一个“反”字即可。设有一数为x,则反码表示可记作[x]

【例1-7】 设X1=+1010110,X2=-1001010,请分别写出它们在8位微机的原码和反码。

解:由于正数的反码就是其原码;负数的反码是符号位不变,数值位是它的数值位的按位取反,所以有

[X1]=01010110

[X1]=[X1]=01010110

[X2]=11001010

[X2]=10110101

反码通常作为求补过程的中间形式,即在一个负数的反码的末位上加1,就得到了该负数的补码。

3.补码

补码的概念是在计算机中经常会遇到的,二进制数的补码可由反码得到,如果是正数,则该机器数的补码与原码一样;如果是负数,则该机器数的补码是对它的原码(除符号位外)各位取反,并在末位加1而得到的。补码的标记方法和原码、反码类似,只要在被括数方括号的右下角添加一个“补”字即可。设有一数X,则X的补码表示记作[X]

【例1-8】 设X1=+1010B,X2=-01010B,试分别写出它们在8位微机中的原码、反码和补码形式。

解:由原码、反码和补码的定义得

[X1]=00001010B[X2]=10001010B

[X1]=00001010B[X2]=11110101B

[X1]=00001010B[X2]=11110110B

补码的优点是可以将减法运算转换为加法运算,其符号位可以连同数值位一起运算。这样非常有利于计算机的实现。

【例1-9】 45H,-55H,用补码运算的方法求两数之和。

解:[45H]-[-55H]=[-10H]

1.3.2 计算机中二进制数的单位表示

在计算机中使用的二进制数共有3个单位,从小到大依次为位、字节和字。

1.位(bit)

这里所说的位是指二进制数的位。位是数的最小单位,bit是位的英文名称,读作“比特”。

在计算机中位仅有0和1两个数值,表示两种状态。

2.字节(Byte)

8位二进制数称为一个字节,其英文名称是Byte,在使用时常用大写字母B表示。字节是最基本的数据单位,计算机中的数据、代码、指令、地址多以字节为单位。

3.字(Word)

字是一台计算机上所能并行处理的二进制数,字的位数(或长度)称之为字长。字长必须是字节的整数倍。例如,MCS-51单片机字长为8位,MCS-96单片机字长为16位,还有32位、64位字长的计算机。

1.3.3 计算机使用二进制数的原因

为什么在计算机中要使用二进制数呢?其原因主要有以下几点:

1.易于实现

在计算机中,数是用不同的物理状态来表示的。因为二进制数只有两个数字0和1,用两种物理状态就可以表示出来。而两种相反的物理状态在技术上极易实现。例如,开关的接通与断开,晶体管的导通与截止,电平的高低,脉冲的有无等。

对于这样两种截然相反的物理状态,不但易于实现,而且状态稳定可靠。而两种以上的物理状态,不但难以实现,而且稳定性也差。

2.运算简单

因为二进制数只有两个数字,所以对二进制数的运算比人们熟悉的十进制数的运算要简单得多,而运算简单将有利于简化计算机的电路结构。

3.具有逻辑属性

由于二进制数的0和1正好与逻辑值的“假(F)”和“真(T)”相对应,因此可以使用二进制数实现逻辑运算,从而使逻辑代数运算成为可能。

4.可靠性高

由于二进制数用两种截然相反的物理状态表示,十分稳定。因此二进制数的处理、存储和传送都最为可靠。