计算机无法计算的数值用什么表示,计算机组成原理之数据的表示及运算

定点数

定点数:计算机中约定机器数小数点位置,小数点的位置固定的数。

定点整数:小数点位置约定在最低位之后

定点小数:小数点位置约定在最高位之后编码方式取值范围(n 位机器数,n从 0 开始数)最大值(以 8 位机器数为例)最小值原码:最高位符号位,数据位为 2 进制真值 ~ 符号位取 0 ,数据位全 1 。0111 1111 : 127符号位取 1,数据位全 1。1111 1111 : -127

反码:最高位为符号位,数据位为原码取反~ 0111 1111 : 1271000 0000: -127

补码:反码值 + 1 。权值公式为~ 0111 1111 : 1271000 0000 -128

移码:补码符号位取反。~ 1111 1111 : 1270000 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单精度浮点数1823327FH

双精度浮点数11152643FFH

临时浮点数11564803FFFH

注:单精度与双精度浮点数采用隐藏尾数最高位策略,数据的最高位总是 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计算机组成原理考研复习指导》、《深入理解计算机系统》

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值