计算机组成原理之数据的表示及运算
定点数
定点数:计算机中约定机器数小数点位置,小数点的位置固定的数。
定点整数:小数点位置约定在最低位之后
定点小数:小数点位置约定在最高位之后
编码方式
取值范围(n 位机器数,n从 0 开始数)
最大值(以 8 位机器数为例)
最小值
原码:最高位符号位,数据位为 2 进制真值
~
符号位取 0 ,数据位全 1 。0111 1111 : 127
符号位取 1,数据位全 1。1111 1111 : -127
反码:最高位为符号位,数据位为原码取反
~
0111 1111 : 127
1000 0000: -127
补码:反码值 + 1 。权值公式为
~
0111 1111 : 127
1000 0000 -128
移码:补码符号位取反。
~
1111 1111 : 127
0000 0000: -128
注:无符号数的编码具有唯一性。有符号数正数的原码、反码、补码相同,移码与补码符号位相反。
运算
移位运算
算数移位:左移一次为乘 2 ,右移一次为除以 2 。
算数移位的对象是带符号数,移位过程中符号位不变。
正数移位直接添 0 ,负数原码反码移位直接添 0 ,补码左移添 0 ,右移添 1 。
逻辑移位:添 0
循环移位:带进位与不带进位的意思是数据位移动的时候带不带 CF 标志位。
不带进位的循环移位:因移动而丢失掉的数据位要存储到 CF 标志位中。CF 标志位不参与循环。
定点数加减运算溢出判断
溢出:运算结果超过机器可以表示的数。ps:产生进位并不等于溢出。
1 位符号位:两操作数符号同,结果与操作数符号不同,则溢出。
2 位符号位:运算结果符号位 S1 异或 S2,结果为 1 则溢出。
01:正溢出
10:负溢出
00:结果为正数,无溢出
11:结果为负数,无溢出
数据位最高位进位情况:与符号位进位不同则溢出。
强制类型转换
C 语言中的类型转换结果保持机器数位值不变,只是改变了解释这些位的方式。
大字长变量向小字长变量转换时直接截断高位部分
小字长变量向大字长变量转换时保持低位不变,高位扩展为原数字的符号位
浮点数
浮点数:小数点位置可变的数。
浮点数一般表示形式.png
IEEE 754标准
IEEE754浮点数表示形式.png
类型
数符
阶码
尾数
总位数
偏移量e
单精度浮点数
1
8
23
32
7FH
双精度浮点数
1
11
52
64
3FFH
临时浮点数
1
15
64
80
3FFFH
注:单精度与双精度浮点数采用隐藏尾数最高位策略,数据的最高位总是 1 ,隐藏最高位可以使尾数多表示 1 位有效位。
单精度浮点数值的分类.jpg
浮点数的加减运算
1. 规格化两操作数
为了提高运算精度,规定尾数的最高位数必须是一个有效值。
单符号位规格化
原码规格化后尾数数据位最高位为 1
补码规格化后正数与原码同,负数数据位最高位为 0 ,形如 1.0XXX XX..
双符号位规格化
正数:00.1XXX XX..
负数:11.0XXX XX..
左规:尾数左移(小数点右移),阶数减小
右规:尾数右移(小数点左移),阶数增大
ps:基数不同时,浮点数的规格化形式也不同。当基数为 4 时,浮点数尾数最高两位不全为 0;基数为 8 时,位数最高三位不全为 0。
2. 对阶
使两操作数阶数相等,小阶向大阶对齐,阶数增大尾数右移。
3. 尾数求和后规格化结果值
4. 舍入
对阶和右规过程中,尾数低位可能会丢失引起误差。
0 舍 1 入法:尾数右移时被舍去的最高数值位为 0 则舍去;被舍去的最高数值位为 1 则在尾数的末位 +1
恒置 1
最简单的舍入方法是直接截断不做处理
浮点数溢出判断:阶码是否超过取值范围。下溢时仅当作机器 0 处理,上溢时计算机必须中断运算操作并进行溢出处理。
参考资料:《2019计算机组成原理考研复习指导》、《深入理解计算机系统》