博客
关于我
计算机网络·数据链路层里的questions
阅读量:96 次
发布时间:2019-02-26

本文共 766 字,大约阅读时间需要 2 分钟。

你能学到什么

数据链路层的三大问题是什么

一、封装成帧

简单地说就是数据链路层收到ip数据报以后,给装上帧首部和帧尾部

在帧首部的是SOH
在帧尾部的是EOT

在这里插入图片描述

二、透明传输

  • 在要传输的数据里,可能会出现帧定界符SOH或者EOT,如果不做处理,接收端就不能收到正确且完整的数据。
  • 我们要做的就是把数据里SOH和EOT变“透明”,不让他俩发挥起始或者终止的作用。(具体怎么做,在下一个板块我们结合协议来说明)

三、差错检测(☆)

  • 循环冗余检验(CRC)
  • 模二运算规则:借位高位不变,能不能商只看首位
  • 除数:除数的位数是(n+1)
    除数一般都会给你,如果给多项式的话,请看下面例子
  • 被除数:在发送端需要加n个0,
    在接收端(收到的是数据+冗余码)就直接算就行
  • 余数(R):在发送端,就是冗余码,发送的时候加在数据后面
    在接收端如果R=0,说明没有差错,否则有差错
  • 算出来的商没有啥用

(下面我们直接上题)

在数据传输过程中,若接收方收到的信息为10110011010,生成多项式G(x)=x^4 + x^3 + 1,请验证传输过程中是否出错。

(老样子,先分析:接收方收到的是10110011010(数据+冗余码),可以直接作为被除数。除数是多项式,咋整见下图)

在这里插入图片描述

下面我们一起来做一下模二运算
在这里插入图片描述

R=0 所以没有差错

PPP协议里的透明传输

一、字节填充

上面我们说到,我们要想办法让数据中有特殊作用的字符变“透明”,由此我们考虑引进转义字符

在PPP协议中0x7D定义为转义字符,具体为:

①每一个0x7E字节转变成0x7D,0x5E
②出现一个0x7D字节,转变成0x7D,0x5D
③数值小于0x20的字符,如0x03转变成0x7D,0x23

二、零比特填充

在发送端,每5个连续的1,插入一个0

在接收端,每5个连续的1,删除一个0

转载地址:http://ycyk.baihongyu.com/

你可能感兴趣的文章
MySQL批量插入数据遇到错误1213的解决方法
查看>>
mysql技能梳理
查看>>
MySQL报Got an error reading communication packets错
查看>>
Mysql报错Can‘t create/write to file ‘/tmp/#sql_3a8_0.MYD‘ (Errcode: 28 - No space left on device)
查看>>
MySql报错Deadlock found when trying to get lock; try restarting transaction 的问题解决
查看>>
MySQL报错ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘
查看>>
Mysql报错Packet for query is too large问题解决
查看>>
mysql报错级别_更改MySQL日志错误级别记录非法登陆(Access denied)
查看>>
Mysql报错:too many connections
查看>>
MySQL报错:无法启动MySQL服务
查看>>
mysql授权用户,创建用户名密码,授权单个数据库,授权多个数据库
查看>>
mysql排序查询
查看>>
MySQL排序的艺术:你真的懂 Order By吗?
查看>>
MySQL排序的艺术:你真的懂 Order By吗?
查看>>
Mysql推荐书籍
查看>>
Mysql插入数据从指定选项中随机选择、插入时间从指定范围随机生成、Navicat使用存储过程模拟插入测试数据
查看>>
MYSQL搜索引擎
查看>>
mysql操作数据表的命令_MySQL数据表操作命令
查看>>
mysql操作日志记录查询_如何使用SpringBoot AOP 记录操作日志、异常日志?
查看>>
MySQL支持的事务隔离级别,以及悲观锁和乐观锁的原理和应用场景?
查看>>