编程模拟实现数据链路层协议中的停等协议_第1页
编程模拟实现数据链路层协议中的停等协议_第2页
编程模拟实现数据链路层协议中的停等协议_第3页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、一、实验题目 :编程模拟实现数据链路层协议中的停等协议二、实验目的 :1、掌握停止等待协议的基本原理2、理解数据链路层的主要功能(数据出错控制,数据重复控制,数据丢失控制等等)3、分析简单的协议数据单元4、掌握停止等待协议的运行机制三、停止等待协议的算法,在发送节点:( 1) 从主机取一个数据帧,送交发送缓存。( 2) 发送状态变量 V(S)初始化, V( S) 0。( 3) 将发送状态变量值写入数据帧中的发送序号 N( S),N(S) V( S)。( 4) 将发送缓存中的数据帧发送出去。( 5) 设置超时计时器(选择适当的超时重传时间 Tout )。( 6) 等待。( 7) 收到确认帧 AC

2、Kn,若 n=1-V(S),则: 从主机取一个新的数据帧,放入发送缓存: V(S) 1-V(S);转到( 3)。否则,丢弃这个确认帧,转到( 6)。( 8) 若超时计时器时间到,则转到( 4)。在接收节点:( 1) 接收状态变量初始化, V(R) 0。( 2) 等待。( 3) 收到一个数据帧:若 N(S)=V(R),则执行( 4);否则丢弃此数据帧,然后转到(6)。( 4) 将收到的数据帧中的数据部分送交上层软件。( 5) 更新接收状态变量,准备接收下一个数据帧, V(R) 1-V(R)。( 6) nV(R),发送确认帧 ACK,转到( 2)。四、程序源代码:#include <iost

3、ream>#include <>#include <>#include <>d to %d.%dnn",LOBYTE, HIBYTE,LOBYTE, HIBYTE);void mksock(int type)PrimaryUDP = socket(AF_INET, type,0);if (PrimaryUDP < 0)throw Exception("create socket error");void BindSock()d to %d.%dnn",LOBYTE, HIBYTE,LOBYTE, HIBYT

4、E);void rmksock(int type)PrimaryUDP = socket(AF_INET, type,0);if (PrimaryUDP < 0)throw Exception("create socket error");void rBindSock()sockaddr_in sin;= INADDR_ANY;= AF_INET;= htons(SERVER_PORT);if (bind(PrimaryUDP, (struct sockaddr*)&sin, sizeof(sin) < 0)throw Exception("bind error");DWORD WINAPI rARecv(LPVOIDlpParam)FILE * file = NULL;sockaddr_in remote;int sinlen = sizeof(remote);BSC buffer,bsc;= STX; = ETX;memset, 0, MAXBSCLENGTH);int iread = 0;unsigned long dwReceived = 0;boolnumber=true;算机网络(第4版) .Andrew2

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论