计算机基础理论:原码、反码、补码、移码(2009-04-23 00:02:36)
一、标准理论 1、原码的定义 ①小数原码的定义
例如: X=+0.1011 , [X]原= 01011 ②整数原码的定义
2、补码的定义 ①小数补码的定义
例如: ②整数补码的定义
①小数反码的定义
②整数反码的定义
4.移码:移码只用于表示浮点数的阶码,所以只用于整数。 ①移码的定义:设由1位符号位和n位数值位组成的阶码,则 [X]移=2n + X ②移码与补码的关系: [X]移与[X]补的关系是符号位互为反码, ③移码运算应注意的问题: 二、补码加、减运算规则1、运算规则[X+Y]补= [X]补+ [Y]补
|
高位部分积 | 低位部分积/乘数 | 说明 | |||
|
1 0 1 1 | 起始情况 | |||
+) 0 0 1 1 0 1 | 乘数最低位为1,+X | ||||
|
|||||
|
|||||
|
1 1 0 1 | 1(丢) | 右移部分积和乘数 | ||
+) 0 0 1 1 0 1 | 乘数最低位为1,+X | ||||
|
|||||
|
|||||
|
1 1 1 0 | 1(丢) | 右移部分积和乘数 | ||
+) 0 0 0 0 0 0 | 乘数最低位为0,+0 | ||||
|
|||||
|
|||||
|
1 1 1 1 | 0(丢) | 右移部分积和乘数 | ||
+) 0 0 1 1 0 1 | 乘数最低位为1,+X | ||||
|
|||||
|
|||||
|
1 1 1 1 | 1(丢) | 右移部分积和乘数 | ||
部分积 | 低位部分积 附加位 | 操作说明 | |||
|
|
起始情况 | |||
+) 0 0 0 0 0 0 | 乘数最低位为1,+X | ||||
|
|||||
|
|||||
|
1 1 0 1 | 1(丢) | 右移部分积和乘数 | ||
+) 1 1 0 0 1 1 | 乘数最低位为1,+X | ||||
|
|||||
|
|||||
|
1 1 1 0 | 1(丢) | 右移部分积和乘数 | ||
+) 0 0 0 0 0 0 | 乘数最低位为0,+0 | ||||
|
|||||
|
|||||
|
1 1 1 1 | 0(丢) | 右移部分积和乘数 | ||
+) 0 0 1 1 0 1 | 乘数最低位为1,+X | ||||
|
|||||
|
|||||
|
1 1 1 1 | 1(丢) | 右移部分积和乘数 |
§2.5 浮点运算与浮点运算器
设两个浮点数 X=Mx※2Ex Y=My※2Ey
实现X±Y要用如下5步完成:
①对阶操作:小阶向大阶看齐
②进行尾数加减运算
③规格化处理:尾数进行运算的结果必须变成规格化的浮点数,对于双符号位的补码尾数来说,就必须是
001×××…×× 或110×××…××的形式
若不符合上述形式要进行左规或右规处理。
④舍入操作:在执行对阶或右规操作时常用“0”舍“1”入法将右移出去的尾数数值进行舍入,以确保精度。
⑤判结果的正确性:即检查阶码是否溢出
若阶码下溢(移码表示是00…0),要置结果为机器0;
若阶码上溢(超过了阶码表示的最大值)置溢出标志。
例题:假定X=0 .0110011*211,Y=0.1101101*2-10(此处的数均为二进制) ?? 计算X+Y;
解:[X]浮: 0 1 010 1100110
第一步:求阶差: │ΔE│=|1010-0110|=0100
第二步:对阶:Y的阶码小, Y的尾数右移4位
第三步:尾数相加,采用双符号位的补码运算
第四步规格化:满足规格化要求
第五步:舍入处理,采用0舍1入法处理
故最终运算结果的浮点数格式为: 0 1 010 1101101,
即X+Y=+0. 1101101*210
①阶码运算:阶码求和(乘法)或阶码求差(除法)
②浮点数的尾数处理:浮点数中尾数乘除法运算结果要进行舍入处理
例题:X=0 .0110011*211,Y=0.1101101*2-10
求X※Y
解:[X]浮: 0 1 010 1100110
第一步:阶码相加
[Ex+Ey]移=[Ex]移+[Ey]补=1 010+1 110=1 000
1 000为移码表示的0
第二步:原码尾数相乘的结果为:
0 10101101101110
第三步:规格化处理:已满足规格化要求,不需左规,尾数不变,阶码不变。
第四步:舍入处理:按舍入规则,加1进行修正
所以 X※Y= 0.1010111※2+000
chapter two
计算机内部,数是用二进制表示的。二进制数的编码方式有补码、原码、反码