当前位置: 首页 > news >正文

【系统架构设计师】计算机组成与体系结构 ⑯ ( 奇偶校验码 | CRC 循环冗余码 | 海明码 | 模 2 除法 )

文章目录

  • 一、校验码
    • 1、校验码由来
    • 2、奇偶校验码
    • 3、CRC 循环冗余码 ( 重点考点 )
    • 4、海明码校验 ( 软考不经常考到 )
  • 二、CRC 循环冗余码 ( 重点考点 )
    • 1、模 2 除法概念
    • 2、模 2 除法步骤
    • 3、模 2 除法示例
    • 4、CRC 循环冗余码示例 1
    • 5、CRC 循环冗余码示例 2


参考之前的博客 :

  • 【计算机网络】数据链路层 : 差错控制 ( 检错编码 | 奇偶校验码 | CRC 循环冗余码 )★
  • 【计算机网络】数据链路层 : 差错控制 ( 纠错编码 | 海明码 | “海明码“ 原理 | “海明码“ 工作流程 | 确定校验啊位数 | 确定校验码和数据位置 | 求校验码值 | 检错纠错 )★




一、校验码




1、校验码由来


计算机 数据 传输时 , 数据 可能会因为 电磁干扰、硬件故障等原因 出现 1 变 0 或 0 变 1 的错误 ;

校验码 可以 通过 增加冗余信息 来 检测和纠正 数据传输 过程中的 错误 , 可 提高数据传输的可靠性 , 确保数据的 完整性和准确性 ;

常用的校验码有 :

  • 奇偶校验码
  • CRC 循环冗余码
  • 海明码

2、奇偶校验码


奇偶校验码 是在 数据的有效信息 之外 , 追加一位 , 组成校验码 ;

  • 奇校验 : 1 的个数为 奇数 , 追加的 冗余校验码位为 1 ;
  • 偶校验 : 1 的个数为 偶数 , 追加的 冗余校验码位为 0 ;

如果 正好有 2 位出现了错误 ,

  • 两个 1 变成了 0 ,
  • 两个 0 变成了 1 ,
  • 一个 1 变成了 0 , 一个 0 变成了 1 ,

就无法检查出错误 ; 同理 , 如果有 4 位出现了错误 , 也无法检查出来 ;


奇偶校验码 只能检查 奇数个 比特错误 , 如果有 偶数个比特错误 , 无法检查出来 , 检错率是 50 % ;

奇偶校验码 只能检查错误 , 不能纠错 ;

  • 纠错的前提是知道错误位置 , 将其取反即可 , 找不到错误位置 , 就无法进行纠错 ;

3、CRC 循环冗余码 ( 重点考点 )


CRC 循环冗余码 是 基于模 2 运算的校验码 , 通过将 数据 视为一个 多项式 并使用除法运算生成校验码 ;

CRC 循环冗余码 能够 检测错误 , 但是不能进行纠错 ;

CRC 循环冗余码 会在 信息位 之后 拼接 多位校验位 , 不是 奇偶校验码 的 一位 , 增加的冗余校验位增加 , 相对发现错误的几率也会更大 ;


CRC 循环冗余码 在 k 位信息后 , 拼接 r 位 校验码 , 这里涉及到两个问题 :

  • 发送端 : 根据 k 位信息 , 计算出 r 位 校验码 ;
  • 接收端 : 根据 k + r 位的信息 , 检验数据是否正确 ;

具体参考 【计算机网络】数据链路层 : 差错控制 ( 检错编码 | 奇偶校验码 | CRC 循环冗余码 )★ 博客中的内容 ;


4、海明码校验 ( 软考不经常考到 )


海明码校验 的 原理 是 通过 交叉校验的方式 , 形成了多组不同的 奇偶校验 ;

海明码 在 2 的幂次方的位置 插入校验位来工作 , 即位置1, 2, 4, 8, 16等 , 校验位的数量 取决于需要编码的数据位的数量 ;


校验位的数量 p 满足以下不等式 :

2 p ≥ n + p + 1 2^p ≥ n+p+1 2pn+p+1

  • p 是校验位数量 ;
  • n 是原始数据的位数 ;

具体的案例 , 参考 【计算机网络】数据链路层 : 差错控制 ( 纠错编码 | 海明码 | “海明码“ 原理 | “海明码“ 工作流程 | 确定校验啊位数 | 确定校验码和数据位置 | 求校验码值 | 检错纠错 )★ 博客 ;


在架构师考试时 , 该知识点不经常考到 , 掌握校验位个数的公式即可 ;





二、CRC 循环冗余码 ( 重点考点 )




1、模 2 除法概念


" 模 2 除法 " , 又称为 " 二进制除法 " 或 " 模 2 运算中的除法 " ;

" 模 2 除法 " 是一种 在 二进制数 系统 中执行的除法运算 , 与普通的 十进制除法 不同 , 模 2 除法中的所有运算都是基于 二进制 进行 ;

" 模 2 除法 " 在 除法运算过程中 , 不进行 借位 , 直接得到 借位 后的结果 ;

" 模 2 除法 " 在 计算过程中 , 每一步的 结果 与 " 异或运算 " 的结果是一样的 , " 异或运算 " 是 二者相同 则为假 , 二者不同则为真 ;


2、模 2 除法步骤


" 模 2 除法 " 步骤 :

  • 设置 被除数 和 除数 : 设置 两个 二进制数 , 一个作为 被除数 , 另一个作为除数 ;
  • 模 2 除法过程 ( 异或运算 ) :
    • 从 被除数 的最高位开始 , 将其与 除数 进行比较 ;
      • 这里每一位都按照 " 异或运算 " , 进行计算 ;
    • 重复上述步骤 , 直到处理完被除数的所有位 ;
  • 得到商和余数 : 完成上述步骤后 , 得到一个二进制数作为商 , 以及一个二进制数作为余数 , 余数就是 校验位 ;

3、模 2 除法示例


下面的运算就是一个 模 2 除法 :

在这里插入图片描述

第一步计算中 ,

  • 红色矩形框 中 1 减去 0 , 得 1 是正常的 ,
  • 蓝色矩形框 中 0 减去 1 , 按照普通除法来算的话 , 需要向前借一位 , 但是此时不进行借位 , 仍然得到结果 1 ;
  • 绿色矩形框 中 , 1 减去 1 , 得到的结果是 0 ;

异或运算 规律 :

  • 可以看到上述结果 不管是 1 和 0 还是 0 和 1 最终得到的结果都是 1 ;
  • 但是 如果 上下两位 都是 1 或者 都是 0 , 最终得到的结果就是 0 ;
  • 上述规律得到的结果与 异或运算 是相同的 ;

在这里插入图片描述


第二步中 ,

  • 红色矩形框 中 1 与 0 进行 异或运算 , 得到的结果是 1 ;
  • 蓝色矩形框 中 1 与 1 进行 异或运算 , 得到的结果是 0 ;

最终得到 011 , 小于 110 , 011 就是余数 , 商为 110 ;

在这里插入图片描述


4、CRC 循环冗余码示例 1


【计算机网络】数据链路层 : 差错控制 ( 检错编码 | 奇偶校验码 | CRC 循环冗余码 )★ 博客中也有一个 CRC 编码示例 , 可结合参考 ;


原始报文是 10111 , 生成多项式为 G ( x ) = x 4 + x + 1 G(x) = x^4 + x + 1 G(x)=x4+x+1 , 计算编码后的发送数据 ;

生成多项式 是 发送方 和 接收方 约定好的 ;


计算 帧检验序列 FCS :

① 数据加 冗余码 位数个 0 0 0 : 首先确定 冗余码 位数 , 冗余码的位数是 生成多项式的 阶 加上 1 , 即 生成多项式 的 总位数 减去 1 1 1 , 相当于 离散数学 中的生成函数的 最高位次幂 ; FCS 的位数是 4 4 4 位 ;

生成多项式 是 N N N 位 , 那么阶 就是 N − 1 N-1 N1 位 , FCS 帧检验序列就是 N − 1 N-1 N1 位 ;

生成多项式为 G ( x ) = x 4 + x + 1 G(x) = x^4 + x + 1 G(x)=x4+x+1 , 阶为 4 , FCS 帧检验序列是 4 位 , 其二进制形式有 5 位 ;

10111 数据加 4 4 4 0 0 0 后为 101110000 10111 0000 101110000 ;


② 生成多项式 转为二进制 :

G ( x ) = x 4 + x + 1 G(x) = x^4 + x + 1 G(x)=x4+x+1

将空位补齐后为 :

G ( x ) = 1 x 4 + 0 x 3 + 0 x 2 + 1 x 1 + 1 x 0 G(x) = 1x^4 + 0x^3 + 0x^2 + 1x^1 + 1x^0 G(x)=1x4+0x3+0x2+1x1+1x0

将生成多项式转为二进制形式后为 : 10011 10011 10011 ;


② 模 2 2 2 除法 : 数据 加上 0 0 0 后 , 除以 生成多项式 , 余数就是 FCS 帧检验序列 ;

二进制除法 , 与十进制除法不同的是 , 每个除法相除的计算是 异或操作 ;

异或运算 : 同 0 0 0 , 异 1 1 1 ;

在这里插入图片描述

2 2 2 除法计算过程分析 : 被除数 9 位 ( 1 ~ 9 计数 ) , 除数 5 位 ( 1 ~ 5 计数 ) ;

  • 10111 10111 10111 异或 10011 10011 10011 计算得到 100 100 100 , 然后第六位 0 0 0 落下来 , 得到 1000 1000 1000 ;
  • 1000 1000 1000 位数不足 , 继续第七位 0 0 0 落下来 , 得到 10000 10000 10000 ;
  • 10000 10000 10000 异或 10011 10011 10011 计算得到 11 11 11 , 然后下面第八位 落下来 , 得到 110 110 110 ;
  • 110 110 110 位数不足 , 继续第九位 0 0 0 落下来 , 得到 1100 1100 1100 ;

最终的余数是 1100 , 这也是 FSC 帧检验序列 ;


最终计算出来的 帧检验序列 是 1100 1100 1100 ;

最终发送的数据是 : 10111 10111 10111 1100 1100 1100



接收端接收数据并校验 :

① 检验过程 : 接收端接收 上述 10111 10111 10111 1100 1100 1100 数据 , 将上述数据 与 生成多项式 10011 10011 10011 相除 , 如果余数为 0 0 0 说明该数据帧没有差错 ;

② 结果判定 : 如果余数不为 0 0 0 , 说明数据帧错误 , 而且不知道哪里出现错误 , 丢弃该数据帧 , 重新发送 ;


5、CRC 循环冗余码示例 2


传输数据位 111000110 , 生成多项式为 G ( x ) = x 5 + x 3 + x + 1 G(x) = x^5 + x^3 + x + 1 G(x)=x5+x3+x+1 , 计算 CRC 循环冗余校验码 ;

生成多项式 是 发送方 和 接收方 约定好的 ;


生成多项式为 G ( x ) = x 5 + x 3 + x + 1 G(x) = x^5 + x^3 + x + 1 G(x)=x5+x3+x+1 , 补齐后为 :

G ( x ) = 1 x 5 + 0 x 4 + 1 x 3 + 0 x 2 + 1 x 1 + 1 x 0 G(x) = 1x^5 + 0x^4 + 1x^3 + 0x^2 + 1x^1 + 1x^0 G(x)=1x5+0x4+1x3+0x2+1x1+1x0

得到的二进制形式为 101011 ;


进行模 2 除法 : 111000110 ÷ 101011 111000110 \div 101011 111000110÷101011 , 得到余数 11001 11001 11001 ;

在这里插入图片描述

余数 11001 11001 11001 就是校验码 ;

最终的发送序列为 : 111000110 111000110 111000110 11001 11001 11001

  • 蓝色为原始数据 ;
  • 红色为校验序列 ;

相关文章:

【系统架构设计师】计算机组成与体系结构 ⑯ ( 奇偶校验码 | CRC 循环冗余码 | 海明码 | 模 2 除法 )

文章目录 一、校验码1、校验码由来2、奇偶校验码3、CRC 循环冗余码 ( 重点考点 )4、海明码校验 ( 软考不经常考到 ) 二、CRC 循环冗余码 ( 重点考点 )1、模 2 除法概念2、模 2 除法步骤3、模 2 除法示例4、CRC 循环冗余码示例 15、CRC 循环冗余码示例 2 参考之前的博客 : 【计…...

springboot,service 层统一异常抛出时,throws Exception写在接口上还是实现类上

springboot,service 层统一异常抛出时,throws Exception写在实现接口上,不是直接写在实现类上...

深度学习高效性网络

为了减轻Transformer笨重的计算成本,一系列工作重点开发了高效的Vision Transformer,如Swin Transformer、PVT、Twins、CoAtNet和MobileViT。 1、字节TRT-ViT 兼具CNN的速度、Transformer精度的模型 TRT-ViT(Transformer-based Vision Tra…...

PyQt ERROR:ModuleNotFoundError: No module named ‘matplotlib‘

Solution:打开cmd输入指令下载malplotlib pip install matplotlib...

Flutter Geolocator插件使用指南:获取和监听地理位置

Flutter Geolocator插件使用指南:获取和监听地理位置 简介 geolocator 是一个Flutter插件,提供了一个简单易用的API来访问特定平台的地理位置服务。它支持获取设备的最后已知位置、当前位置、连续位置更新、检查设备上是否启用了位置服务,以…...

网站基本布局CSS

代码 <!DOCTYPE html> <html> <head><meta charset"utf-8"><meta name"viewport" content"widthdevice-width, initial-scale1"><title></title><style type"text/css">body {margi…...

ssm框架整合,异常处理器和拦截器(纯注解开发)

目录 ssm框架整合 第一步&#xff1a;指定打包方式和导入所需要的依赖 打包方法&#xff1a;war springMVC所需依赖 解析json依赖 mybatis依赖 数据库驱动依赖 druid数据源依赖 junit依赖 第二步&#xff1a;导入tomcat插件 第三步&#xff1a;编写配置类 SpringCon…...

古籍双层PDF制作教程:保姆级古籍数字化教程

在智慧古籍数字化项目中&#xff0c;很多图书馆要求将古籍导出为双层PDF&#xff0c;并且确保输出双层PDF底层文本与上层图片偏移量控制在1毫米以内。那么本教程带你使用古籍数字化平台&#xff0c;3分钟把一个古籍书籍转化为双侧PDF。 第1步&#xff1a;上传古籍 点批量上传…...

Git 删除 远端的分支

要删除 Git 远端的分支&#xff08;例如&#xff1a; V3.2.1.13&#xff09;&#xff1a; 可以执行以下命令 git push origin --delete V3.2.1.13这条命令会向远端的仓库删除名为 V3.2.1.13 的分支。如果这个分支只在远端仓库存在而没有对应的本地分支&#xff0c;那么删除后这…...

PrgogressBar实现原理分析

ProgressBar 是 Android 中用于显示进度条的控件&#xff0c;它可以用来表示任务的完成程度或者加载进度等信息。ProgressBar 有两种主要类型&#xff1a;一种是确定性的&#xff08;determinate&#xff09;&#xff0c;另一种是不确定性的&#xff08;indeterminate&#xff…...

【HarmonyOS】HarmonyOS NEXT学习日记:七、页面与组件的生命周期

【HarmonyOS】HarmonyOS NEXT学习日记&#xff1a;七、页面与组件的生命周期 页面和组件 组件&#xff1a;用Component装饰的代码称为自定义组件页面&#xff1a;Entry装饰的组件即页面的根节点 组件生命周期 aboutToAppear&#xff1a;在创建自定义组件的新实例后&#xf…...

【iOS】——Block循环引用

循环引用原因 如果在Block中使用附有_ _strong修饰符的对象类型自动变量&#xff0c;那么当Block从栈复制到堆时&#xff0c;该对象为Block所持有&#xff0c;这样容易引起循环引用。 HPPerson *person [[HPPerson alloc] init];person.block ^{NSLog("person.age--- …...

shell脚本自动化安装启动各种服务

1、自动化配置dns服务器 A主机&#xff1a;vim dns.sh #!/bin/bash# 自动化部署dns# 1、下载bind# 2、修改配置文件# vim /etc/named.conf # listen-on port 53 { 127.0.0.1;any; }; 修改&#xff08;定位替换&#xff09;# allow-query { localhost;any; }; 修改&am…...

Python - 开源库 ReportLab 库合并 CVS 和图像生成 PDF 文档

欢迎关注我的CSDN&#xff1a;https://spike.blog.csdn.net/ 本文地址&#xff1a;https://spike.blog.csdn.net/article/details/140281680 免责声明&#xff1a;本文来源于个人知识与公开资料&#xff0c;仅用于学术交流&#xff0c;欢迎讨论&#xff0c;不支持转载。 Report…...

Java编写SIP协议

1、编写Server代码 package com.genersoft.iot.vmp.sip; import javax.sip.*; import javax.sip.message.*; import javax.sip.header.*; import java.util.*;public class SimpleSipServer implements SipListener {private SipFactory sipFactory;private SipStack sipStack…...

大型语言模型LLM的核心概念

本文主要介绍了目前主流的&#xff0c;几个大型语言模型LLM的整个训练过程 通常分为下面的几个阶段 1. 预训练 采用互联网上的大量数据进行训练&#xff0c;这一阶段大模型LLM的主体已定&#xff0c;找出共性并且压缩成一个模型。模型的参数量不是越大越好&#xff0c;遵循合理…...

软件测试---网络基础、HTTP

一、网络基础 &#xff08;1&#xff09;Web和网络知识 网络基础TCP/IP 使用HTTP协议访问Web WWW万维网的诞生 WWW万维网的构成 &#xff08;2&#xff09;IP协议 &#xff08;3&#xff09;可靠传输的TCP和三次握手策略 &#xff08;4&#xff09;域名解析服务DNS &#xff0…...

韩顺平0基础学java——第39天

p820-841 jdbc和连接池 1.JDBC为访问不同的数据库提供了统一的接口&#xff0c;为使用者屏蔽了细节问题。 2.Java程序员使用JDBC&#xff0c;可以连接任何提供了JDBC驱动程序的数据库系统&#xff0c;从而完成对数据库的各种操作。 3.jdbc原理图 JDBC带来的好处 2.JDBC带来的…...

Linux文件恢复

很麻烦 一般还是小心最好 特别恢复的时候 可能不能选择某个文件夹去扫描恢复 所以 删除的时候 用rm -i代替rm 一定小心 以及 探索下linux的垃圾箱机制 注意 一定要恢复到不同文件夹 省的出问题 法1 系统自带工具 debugfs 但是好像不能重启&#xff1f; testdisk 1、安装 …...

大数据的数据质量有效提升的研究

大数据的数据质量有效提升是一个涉及多个环节和维度的复杂过程。以下是从数据采集、处理、管理到应用等方面&#xff0c;对大数据数据质量有效提升的研究概述&#xff1a; 一、数据采集阶段 明确采集需求&#xff1a;在数据采集前&#xff0c;需明确数据需求&#xff0c;包括…...

从WWDC看苹果产品发展的规律

WWDC 是苹果公司一年一度面向全球开发者的盛会&#xff0c;其主题演讲展现了苹果在产品设计、技术路线、用户体验和生态系统构建上的核心理念与演进脉络。我们借助 ChatGPT Deep Research 工具&#xff0c;对过去十年 WWDC 主题演讲内容进行了系统化分析&#xff0c;形成了这份…...

安宝特方案丨XRSOP人员作业标准化管理平台:AR智慧点检验收套件

在选煤厂、化工厂、钢铁厂等过程生产型企业&#xff0c;其生产设备的运行效率和非计划停机对工业制造效益有较大影响。 随着企业自动化和智能化建设的推进&#xff0c;需提前预防假检、错检、漏检&#xff0c;推动智慧生产运维系统数据的流动和现场赋能应用。同时&#xff0c;…...

【SpringBoot】100、SpringBoot中使用自定义注解+AOP实现参数自动解密

在实际项目中,用户注册、登录、修改密码等操作,都涉及到参数传输安全问题。所以我们需要在前端对账户、密码等敏感信息加密传输,在后端接收到数据后能自动解密。 1、引入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId...

【位运算】消失的两个数字(hard)

消失的两个数字&#xff08;hard&#xff09; 题⽬描述&#xff1a;解法&#xff08;位运算&#xff09;&#xff1a;Java 算法代码&#xff1a;更简便代码 题⽬链接&#xff1a;⾯试题 17.19. 消失的两个数字 题⽬描述&#xff1a; 给定⼀个数组&#xff0c;包含从 1 到 N 所有…...

【学习笔记】深入理解Java虚拟机学习笔记——第4章 虚拟机性能监控,故障处理工具

第2章 虚拟机性能监控&#xff0c;故障处理工具 4.1 概述 略 4.2 基础故障处理工具 4.2.1 jps:虚拟机进程状况工具 命令&#xff1a;jps [options] [hostid] 功能&#xff1a;本地虚拟机进程显示进程ID&#xff08;与ps相同&#xff09;&#xff0c;可同时显示主类&#x…...

佰力博科技与您探讨热释电测量的几种方法

热释电的测量主要涉及热释电系数的测定&#xff0c;这是表征热释电材料性能的重要参数。热释电系数的测量方法主要包括静态法、动态法和积分电荷法。其中&#xff0c;积分电荷法最为常用&#xff0c;其原理是通过测量在电容器上积累的热释电电荷&#xff0c;从而确定热释电系数…...

腾讯云V3签名

想要接入腾讯云的Api&#xff0c;必然先按其文档计算出所要求的签名。 之前也调用过腾讯云的接口&#xff0c;但总是卡在签名这一步&#xff0c;最后放弃选择SDK&#xff0c;这次终于自己代码实现。 可能腾讯云翻新了接口文档&#xff0c;现在阅读起来&#xff0c;清晰了很多&…...

数据库——redis

一、Redis 介绍 1. 概述 Redis&#xff08;Remote Dictionary Server&#xff09;是一个开源的、高性能的内存键值数据库系统&#xff0c;具有以下核心特点&#xff1a; 内存存储架构&#xff1a;数据主要存储在内存中&#xff0c;提供微秒级的读写响应 多数据结构支持&…...

2025年低延迟业务DDoS防护全攻略:高可用架构与实战方案

一、延迟敏感行业面临的DDoS攻击新挑战 2025年&#xff0c;金融交易、实时竞技游戏、工业物联网等低延迟业务成为DDoS攻击的首要目标。攻击呈现三大特征&#xff1a; AI驱动的自适应攻击&#xff1a;攻击流量模拟真实用户行为&#xff0c;差异率低至0.5%&#xff0c;传统规则引…...

验证redis数据结构

一、功能验证 1.验证redis的数据结构&#xff08;如字符串、列表、哈希、集合、有序集合等&#xff09;是否按照预期工作。 2、常见的数据结构验证方法&#xff1a; ①字符串&#xff08;string&#xff09; 测试基本操作 set、get、incr、decr 验证字符串的长度和内容是否正…...