【计算机网络】第三章——差错检测

个人主页:兜里有颗棉花糖

欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 兜里有颗棉花糖 原创

收录于专栏【计算机网络

本专栏旨在分享学习计算机网络的一点学习笔记,欢迎大家在评论区交流讨论💌

目录

一、比特差错

比特差错:

如下图所示,比特流在传输过程中由于受到各种干扰,就可能出现比特差错(或误码)。

误码率:

比特在传输过程中由于误码出现了错误,那么接收方的数据链路层通过什么方法可以知道比特出现了错误呢?我们可以使用差错检错码来对比特进行检查。

差错检测码:

我们拿以太网版本2的MAC帧格式来进行举例:帧尾中包含了一个长度为4字节的帧检测序列FCS字段(其作用就是让接收方的数据链路层检查帧在传输过程中出现了误码)

我们再拿点对点协议PPP帧的格式:帧尾中也包含了两字节的帧检测序列FSC片段(其作用也是接收方的数据链路层检查帧在传输过程中出现了误码)。

二、奇偶校验

奇偶校验:

我们依然进行举例说明:

  • 下面是一个待发送的数据,假设收发双方采用奇校验,那么在数据后面添加的校验位应该为比特1,使得比特1的总数为奇数,假设传输过程中产生了1为误码,我们用红色表示。接收方对受到的比特流进行奇校验,发现比特1的总数为偶数而不是奇数,因此就知道传输过程中发生了误码。所以,采用奇校验的话,如果比特1的数目的奇性发生改变的话,此时可以检测出错误。
  • 但是如果传输过程中产生了两位误码,接收方对受到的比特流进行奇校验,发现比特1的总数为奇数,此时就认为比特流传输过程中没有发生误码。所以,采用奇校验,如果比特1的奇性不改变,此时就无法检测出错误。
  • 现在我们假设收发双方规定使用偶校验,那么在数据后面添加的校验位应该为比特0,使得比特1的总数为偶数。假设比特流传输过程中产生了一位误码,接收方对受到的比特流进行偶校验,发现比特1的总数是奇数而不是偶数,就知道比特流传输过程中发生了误码。所以,采用偶校验的话,如果比特1的数量的偶性发生改变的话,此时可以检查出错误。但是如果比特流传输过程中产生了2位误码,接收方对接收到的比特流进行偶校验,发现比特1的总数位偶数,此时就会误认为没有发生误码。因此采用偶校验,如果比特1的数量的偶性如果不改变的话,此时就检查不出错误。

现在对上述过程进行总结:

  • 如果有奇数个位发生误码,奇偶性发生变化,可以检查出错误
  • 如果有偶数个位发生误码,奇偶性不发生变化,不能检查出错误(漏检)(因为每个误码会对比特1的数量的奇偶性产生影响,影响相互抵消,此时就无法检查出错误)。

由于奇偶性的漏检率比较高,因此一般不会采用这种检测方法(检测比特流在传输过程中是否发生误码)。

下面我们来看循环冗余检验------CRC(Cyclic Redundancy Check

三、循环冗余检验------CRC(Cyclic Redundancy Check)重点

CRC是一种检测能力很强的一种检测方法,漏检率极低。

下图是循环冗余检验的过程:

  • 现在来看发送方的操作:使用除法来计算冗余码,待发送的数据作为被除数的一部分,后面添加生成多项式最高次个0以构成被除数;生成多项式各项系数构成的比特串作为除数。然后进行除法从而得到商和余数。余数就是计算出的冗余码,将其添加到待发送的数据后面一起发送过程如下图:
  • 现在来看接收方的操作,依然是做除法;被除数是接收到的数据;除数仍然是生成多项式各项系数构成的构成的比特串;然后进行除法得到商和余数。如果余数为0,则可以判定比特流传输过程中没有产生误码,否则则可以判定产生了误码。过程如下图:

生成多项式

现在我们对生成多项式进行举例说明:

下图是常用到的生成多项式:

使用这些生成多项式进行CRC校验,可以达到较好的检测效果(即漏检率比较低)。

注意:CRC算法要求生成多项式必须包含最低次项

练习1

将余数添加到待发送数据的后面就可以发送了。

练习2

四、总结

本文到这里就结束了,希望友友们可以支持一下一键三连哈。嗯,就到这里吧,再见啦!!!

相关推荐
weixin_437398219 分钟前
Linux扩展——shell编程
linux·运维·服务器·bash
小林熬夜学编程18 分钟前
【Linux网络编程】第十四弹---构建功能丰富的HTTP服务器:从状态码处理到服务函数扩展
linux·运维·服务器·c语言·网络·c++·http
Hacker_Fuchen20 分钟前
天融信网络架构安全实践
网络·安全·架构
上海运维Q先生22 分钟前
面试题整理15----K8s常见的网络插件有哪些
运维·网络·kubernetes
ProtonBase32 分钟前
如何从 0 到 1 ,打造全新一代分布式数据架构
java·网络·数据库·数据仓库·分布式·云原生·架构
冷心笑看丽美人39 分钟前
探秘 DNS 服务器:揭开域名解析的神秘面纱
linux·运维·服务器·dns
wenxiaocsdn1 小时前
某科技局国产服务器PVE虚拟化技术文档
运维·服务器
远游客07139 小时前
centos stream 8下载安装遇到的坑
linux·服务器·centos
fantasy_arch10 小时前
CPU性能优化-磁盘空间和解析时间
网络·性能优化
LIKEYYLL11 小时前
GNU Octave:特性、使用案例、工具箱、环境与界面
服务器·gnu