【软考中级备考笔记】数据的表示和校验码

2024/2/18 – 数据的表示和校验码 天气:阴雨

春节假期结束后第一个工作日,开始备考中级软件工程师。
希望在今年5月底的软考中取得中级证书
视频地址:https://www.bilibili.com/video/BV1Qc411G7fB

1. 计算机的总体架构

从下图中可以看出,计算机中包含了一下三个层次

  • 最底层的为计算机的硬件部分,对应的知识主要是计算机组成原理
  • 其次是操作系统这一个最大的系统软件,对应了操作系统这门课程
  • 在操作系统之上,是运行的各种应用软件,包含了各种不同的编程语言和数据结构
  • 而位于不同地区的计算机又通过计算机网络连接起来

最终构成了信息化世界。

2. 数据在计算机中的表示

2.1 进制转换

我们知道,任何数据在计算机中都是以二进制的形式表示的。因此我们需要了解不同进制之间是如何进行转换的。首先来看十进制:

实际上,根据十进制的规律,我们可以推广到任何其他的进制,下面是将任意进制转换到十进制的公式:

⚠️⚠️ 这里需要重点注意到是小数部分到进制转换是如何处理的。

下面是一些其他的例子:

记住比较常用的2的几次方幂的结果,会极大的提高我们在进制转换时的效率

除了将任意进制转换为十进制意外,还有一些其他常用的进制转换。蔽日下面的二进制转换到八进制和十六进制:

二进制转换为八进制:

  • 以小数点为中心向两边进行扩充,每三位一组,不满三位的补0。得到的结果就是对应的八进制的数字

同理,二进制转换为十六进制:

  • 以小数点为中心向两边进行扩充,每四位一组,不满四位的补0。得到的结果就是对应的十六进制的数字
2.2 真值和机器数

这个概念相对陌生,实际上非常好理解

  • 真值就是我们平常说的数值
  • 机器数就是数值实际在计算机中存储的形式。数值在计算机中实际存储的形式主要有原码,反码,补码和移码。

此外,还有一个概念是定点数和浮点数

  • 定点数,小数点的位置是固定的,就是我们通常说的小数
  • 浮点数,小数点的位置不固定,和科学技术法非常类似

【软考中级备考笔记】数据的表示和校验码_第1张图片

2.3 原码,反码,补码和移码
2.3.1 原码

首先来看原码,原码分为两部分:

  • 符号位:位于最高位。0表示正数,1表示负数
  • 数值位:表示数值的绝对值

以8位机器码为例,原码的取值范围是:

  • 最小1,1111111 = -127
  • 最大0,1111111 = 127

因此原码的取值范围为[-127,127]

2.3.2 反码

然后我们来看反码。反码的规则是若符号位为0,则反码和原码相同。若符号位为1,则数值位全部取反。因此对于正数而言,反码的原码相同。

以8位机器码为例,反码的取值范围是:

  • 最小1,1111111 = -127
  • 最大0,1111111 = 127

因此反码的取值范围为[-127,127]

2.3.3 补码

对于补码来说,正数的补码等于原码。而对于负数的补码,等于反码的末尾+1。

也可以直接从原码转换的补码,规则是原码除了符号位以外全部取反,末尾+1

对于补码来说,表示0的方式只有1种:

  • 对于+0,对应的补码为0,0000000
  • 对于-0,对应的原码为1,0000000,则对应的补码为1,1111111 + 1 = 100000000 溢出的数据不算,结果还是00000000

以8位机器码为例,补码的取值范围是:

因此补码的取值范围为[-128,127]

2.3.4 移码

移码的计算方法是补码的基础上符号位取反。

对于移码来说,可不是正数的原码和移码相同了!!!

因此移码的取值范围为[-128,127]

2.3.5 小节
  • 对于正数来说,原码,反码和补码均相同。但是移码不遵循这个规律
  • 从0的表示上来看:
    • 原码和反码,0均有两种表示方式
    • 补码和移码,0只有一种表示方式
  • 从取值范围上来看:
    • 原码和反码,[-127,127]
    • 补码和移码,[-128,127]
  • 几种码之间的转换图示如下:

【软考中级备考笔记】数据的表示和校验码_第2张图片

【软考中级备考笔记】数据的表示和校验码_第3张图片

3. 校验码

校验码的作用:

  • 保护数据的正确性,用于检测数据是否出错

码距:指一个编码系统中任意两个合法编码之间至少有多少个二进制位不同

比较常用的校验法如下:

  • 水平奇偶校验码
  • 垂直奇偶校验码
  • 水平垂直奇偶校验码

比较常用的校验码是海明码,具体定义以及例题如下:

比较常见的还有CRC循环冗余校验法,视频里面没有提,后续根据例题看一看是否需要了解一下。

CRC利用生成多项式为k个数据位产生r个校验码来进行编码,其编码长度为k+r

你可能感兴趣的:(软考,软考)