博客
关于我
计算机网络·数据链路层里的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 replace first,MySQL中处理各种重复的一些方法
查看>>
MySQL replace函数替换字符串语句的用法(mysql字符串替换)
查看>>
mysql replace用法
查看>>
Mysql Row_Format 参数讲解
查看>>
mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
查看>>
MySQL Server 5.5安装记录
查看>>
mysql server has gone away
查看>>
mysql slave 停了_slave 停止。求解决方法
查看>>
MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
查看>>
MYSQL sql语句针对数据记录时间范围查询的效率对比
查看>>
mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
查看>>
mysql Timestamp时间隔了8小时
查看>>
Mysql tinyint(1)与tinyint(4)的区别
查看>>
mysql union orderby 无效
查看>>
mysql v$session_Oracle 进程查看v$session
查看>>
mysql where中如何判断不为空
查看>>
MySQL Workbench 使用手册:从入门到精通
查看>>
mysql workbench6.3.5_MySQL Workbench
查看>>
MySQL Workbench安装教程以及菜单汉化
查看>>
MySQL Xtrabackup 安装、备份、恢复
查看>>