> 文章列表 > 数据的表示和运算

数据的表示和运算

数据的表示和运算

文章目录

  • 数制与编码
    • 进制间的转换
      • BCD码
    • 定点数与浮点数
      • 定点数是什么?
      • 浮点数是什么?
      • 定点数与浮点数的区别
      • 机器数和真值
    • 原码、反码、补码、移码
      • 基本定义
      • 整数的加减法
    • 刷题小结
    • 最后

数制与编码

进制间的转换

  1. 二进制、八进制、十进制、十六进制之间的转换不用多说。常见的比如一直除以2拿到余数,再将余数排列起来(从下至上倒着写回去),即除基取余法,对应的还有一个乘积取整法。但是这两种办法比较慢,所以大家肯定还是会用2的多少次方去凑。

数据的表示和运算

二进制、八进制、十进制、十六进制的后缀分别为B、O、D、H

  1. 十进制与任意进制进制之间转换有个公式,等号左边是r进制,右边是十进制。

数据的表示和运算

BCD码

BCD:Binary-Coded Decimal,用二进制编码的十进制。

数据的表示和运算

(5 封私信) BCD码有什么用? - 知乎 (zhihu.com)

典型的BCD码就是8421码

数据的表示和运算

为什么没有十的映射?

BCD码的定义是二进制编码的十进制,十进制里最大就是9,所以映射到9结束。

8421码中1010-10010没有定义。即10-18,那就把这个二进制加6修正,就可以得到正确的数字。如在0000-1001内,就不用修正。

如6+7

0110

0111

————相加

1101,把这个结果加上6(0110)

0110

————相加

10011,将结果补全为八位00010011,四位一取,就是13,而6+7的结果正是13.

这就是计算机计算8421码的方法

除了8421码外,还有余3码和2421码等,每一位对应的权值都不相同。

其中余3码=8421码+0011,是一种无权码,每一位没有对应的权值。

2421码的每一位权值分别四2、4、2、1,表示0-4时最高位为0.表示5-9时最高位为1

奇偶校验

数据的表示和运算

定点数与浮点数

机器数中小数点的位置是固定的吗_百度知道 (baidu.com)

简易讲解定点数与浮点数 - 简书 (jianshu.com)

参考了以上博客

定点数是什么?

小数点确定的数,或者说在这种表达方法中小数点的位置是确定的,那么我们称这种方法表示的数就可以是定点数。比如定点表示法。

数据的表示和运算

数据的表示和运算

浮点数是什么?

浮点数就是小数点不确定的,比如在后面浮点数的表示里有一个部分叫阶码,有些也叫位移数,使得小数点的位置不确定

为什么要有浮点数?

因为浮点数表示的精度更高

定点数与浮点数的区别

定点数小数点固定,浮点数不固定。

定点数的精度比浮点数更低。

机器数和真值

真值就是给人看的,机器数就是机器看的。一般是十进制,也可以是二进制

+3,-5,我们看的懂,就是真值

把数字经过编码后存入计算机的数就是机器数,如补码等。一般是二进制。

机器数和真值不过是一个数字的两种形式。

原码、反码、补码、移码

基本定义

原码 反码 补码 移码
关系 真值写成二进制 原码符号位不变,按位取反 反码+1 真值的基础上加上一个偏置值再写成二进制

有符号整数分别表示的范围:

数据的表示和运算

  • 原码从右往左找到第一个1,然后让它前面的位除符号位外全部取反即可得到它的补码。
  • 一个数的补码从右往左找到第一个1,然后让它前面的位全部按位取反,就可以得到这个数的相反数的补码。(套这个公式前注意主语是补码,不是原码)

假设机器字长为8位,有符号整数补码1000 0000表示的就是-128,注意不是负零。

-128是一个比较特殊的数字,他不能用反码+1去推出补码,而是1 0000 0000-1000 000=1000 000

  • 原码和反码存在正零和负零,补码只有一个正零。
  • 移码由于偏置值确定存在,可以直接以无符号数的形式比较。且移码不能表示小数,只能表示整数

数据的表示和运算

  • 数据的表示和运算

整数的加减法

数据的表示和运算

下面的是文字版:

整数的加减法可以分为两类,无符号整数的加减法和有符号整数的加减法

无符号整数的加减法,加法不用多说,减法需要将减法转为加法。因为减去一个数,等于加上这个数的相反数。

被减数不变,减数全部位按位取反,末位加一(从右往左找到第一个1,然后第一个1前面的数全部取反),然后相加即可。

机器码设为8位,以5-3为例

  1. 写出两个数的原码

00000101

00000011–全部位按位取反再末位加一–>11111101

  1. 将两个数直接相加,多出的位舍弃

舍弃后得到00000010B,即2D。(D表示十进制)

而5-3确实等于2,说明我们算对了

有符号整数的加减法,加法不用多说,减法需要将减法转为加法,即拿到减数的相反数的补码。

被减数不变,减数全部位按位取反,末位加一(从右往左找到第一个1,然后第一个1前面的数全部取反,包括符号位),然后相加即可。

有符号整数和无符号整数都是这个办法,说明可以用一套电路解决

补码的加法让符号位也可以参加运算,使得电路的设计更加简便。
数据的表示和运算

刷题小结

  • 65535=216-1,说明表示65535有16个1,无符号整数表示65535至少需要16位,有符号整数表示65535至少需要17位。
  • 1024=210,权值是从20开始,说明1024是第十一位,所以无符号整数表示1024至少需要11位,有符号整数表示1024至少需要12位。
  • 寄存器里放的内容是补码不是原码(容易粗心忽略)
  • x变成2x,一般选补码算术移位,向左移1位(不是两位,不是移原码)。

原码、反码、补码的移位规则

  • 偏移值为2n时,补码变成移码,其实就是符号位取相反数,但是变成移码后得把移码看成无符号数去比较而不能是有符号数。所以让移码最大其实就是让无符号数最大。
  • 让有符号数的补码最大,则让符号位为0,1尽量在高位
  • 让有符号数的补码最小,则让符号位为1,0尽量在高位(补码取反加1后高位的0就变成了1,原码就负的更多,值就越小)
  • 负数补码高位的1越多,则这个负数的真值越大。
  • [1011]unsigned=1*23+0 *22+1 *21+1 *20=11,1011是一个无符号数,位权相加即可。
  • [1011]signed=-1*23+0 *22+1 *21+1 *20=-5,注意这里的1011为补码,-5为真值,这种办法可以直接由补码算出真值(负权有时很好用)
  • [0011]signed=0*23+0 *22+1 *21+1 *20=3,注意这里的0011为补码,3为真值,这种办法可以直接由补码算出真值
  • 正数符号扩展补0,负数符号扩展补1,同时他们的真值不变。
  • 两个数相加,x为符号位进位,y为最高数值位进位,x异或y得到的值若为1表示溢出,为0表示未溢出。

最后

敬请大佬斧正

82拉菲红酒网