计算机网络6-链路层

喜欢这篇文章吗?喜欢的话去看博主的置顶博客,即可依据分类找到此文章的原版得到更好的体验,

图片及代码显示的问题,笔者深感抱歉,想要更好的体验去原博文即可。


title: 计算机网络6 - 链路层
mathjax: true
date: 2020-03-19 20:03:11
categories: [计算机网络]
tags: [计算机网络]
keywords: [计算机网络]


   就是一串数字

字节计数

   每一帧的第一个数字记录了这一帧的长度,很辣鸡,错位就凉凉

字节填充

   前后加上特殊flag,就像字符串的写法一样,如abc"abc就写成了"abc"abc",这样做导致flag要转码。

位填充

   flag为6个连续的1,发送数据的时候五个连续的1后插入一个0,原理是什么?   编码?下图是一个正常的编码。他只能识别00,01,10,11

0
1
0
1
0
1
.
.
10
11
.
00
01

   这样改进一下呢?(我太菜了mermaid用不好,第一层的1居然在左边)

0
1
0
1
0
1
0
1
.
.
10
.
110
111
.
00
01

   然后就能识别00,01,10,110,111,我们让111作文分割符,110表示11即可。
   为了能让这个更加棒,我们可以把树的高度弄大一点。这里我就不画了。

如何侦错

   搞两个拷贝,不同即错。太low了
   搞hash check sum,这个很棒
   internet校验和 定义函数f(x) = x>=n?f(x%n+x/n):x,n为一个二的幂, check = n-f(sum)-1, 验证: f(check+sum)=n-1,这个是显然的
   循环冗余校验 这个就是使用多项式在系数膜2的剩余体系下的除法运算,将得到的模数添加到最后面用于侦错。

如何纠错

   汉明码 通常使用二的幂-1对齐,如果我们放入k个检验位,则在最多出现一个错误的情况下可以保护2^k-1个位,为什么?二分!我们讲检验位放在1,2,4,8…等地方,然后使用二进制分类的方式对整个序列进行异或即可。解码的时候重新计算检验位,本质上就是在二分。得到的值位0,表示无错误,否则翻转后的位就是错误位。
   卷积码。

侦错还是纠错?

   需要根据错误率来选择

多路复用

   时分和频分

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值