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.可靠性高
由于二进制数用两种截然相反的物理状态表示,十分稳定。因此二进制数的处理、存储和传送都最为可靠。