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

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

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

收录于专栏【计算机网络

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

目录

一、比特差错

比特差错:

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

误码率:

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

差错检测码:

我们拿以太网版本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

四、总结

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

相关推荐
茶杯梦轩5 天前
从零起步学习RabbitMQ || 第二章:RabbitMQ 深入理解概念 Producer、Consumer、Exchange、Queue 与企业实战案例
服务器·后端·消息队列
YuMiao7 天前
gstatic连接问题导致Google Gemini / Studio页面乱码或图标缺失问题
服务器·网络协议
Sinclair10 天前
简单几步,安卓手机秒变服务器,安装 CMS 程序
android·服务器
Rockbean11 天前
用40行代码搭建自己的无服务器OCR
服务器·python·deepseek
茶杯梦轩11 天前
CompletableFuture 在 项目实战 中 创建异步任务 的核心优势及使用场景
服务器·后端·面试
海天鹰12 天前
【免费】PHP主机=域名+解析+主机
服务器
DianSan_ERP12 天前
电商API接口全链路监控:构建坚不可摧的线上运维防线
大数据·运维·网络·人工智能·git·servlet
呉師傅12 天前
火狐浏览器报错配置文件缺失如何解决#操作技巧#
运维·网络·windows·电脑
不是二师兄的八戒12 天前
Linux服务器挂载OSS存储的完整实践指南
linux·运维·服务器
芝士雪豹只抽瑞克五12 天前
Nginx 高性能Web服务器笔记
服务器·nginx