版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
实验报告课程名称:计算机网络实验实验名称:ARQ协议模拟实现院系:计算机科学学院实验日期:2010-11-10班级:07通信工程实验报告日期:2010-11-10姓名:谭才盛学号:071101450037老师批阅签字:_______
实验内容:编写两个计算机程序p1,p2。p1模拟发送方:首先从界面读取待发送字符(每接受一个字符的输入),保存到文件exe1.txt中,并启动计时器;p2模拟接收方,它从exe1.txt中查找是否有新字符到来,并提供模拟界面给用户选择:1.Ack-->接收该字符2.NAK--〉丢弃3.无反应--〉导致超时将用户选择的结果记录到exe2.txt中;接收的字符保存到exe3.txt中。 由于可视化操作不精通,这次实验过程在C++环境下模拟运行。 运行环境:VisualC++6.0 编程思路:新建三个文本文件,每次运行程序开始阶段使系统随机产生100个随机数,并使其转化为字符格式,让P1从界面读取字符,输送到exe1,txt文件中。并启动计时器记录传输时间。读入exe1.txt,若发现有新字符,则提供模拟界面给用户选择接收还是丢弃;若无反应,则输出超时信息。将用户选择的结果记录到exe2.txt中;接收的字符保存到exe3.txt中。文本文件读写一律采用追加模式。 实验步骤: 1.分析ARQ协议模拟实现的一般流程,画出流程图:exe1.txtexe1.txtexe2.txt。1.Ack-->接收该字符2..NAK--〉丢弃.3.无反应--〉导致超时。选择的结果记录到exe2.txt中exe3.txt。接收的字符保存到exe3.txt中P11模拟发送方界面从界面读取字符保存到exe1中,并启动计时器接收新字符P2模拟接收方(ARQ协议流程图)2.结合C++文件操作部分编写源程序:源程序如下:#include"iostream.h"#include"fstream.h"#include"stdlib.h"#include"iomanip.h"#include"time.h"#include"string.h"voidmain(){longcurtime_front_Sender,curtime_rear_Sender, curtime_front_Receiver,curtime_rear_Receiver; curtime_front_Receiver=time(NULL);//定义时钟 charch,choice,str[4],array[100]; inti,tag=0;//定义开关变量 fstreamfile1;fstreamfile2;fstreamfile3; cout<<"打开文件:exe1,exe2,exe3"<<endl; file1.open("exe1.txt",ios::in|ios::out|ios::app); if(file1.fail()) {cout<<"不能打开文件:"<<"exe1"<<endl; exit(0); } file2.open("exe2.txt",ios::in|ios::out|ios::app); if(file2.fail()) {cout<<"不能打开文件:"<<"exe2"<<endl; exit(0); } file3.open("exe3.txt",ios::in|ios::out|ios::app); if(file3.fail()) {cout<<"不能打开文件:"<<"exe3"<<endl; exit(0); } cout<<endl<<endl<<"\t\t\tARQ协议模拟实验\n\n\n"; cout<<"\t\t\t1随机产生字符\n\n\t\t\t2接收\n\n\t\t\t3退出"<<endl; do {cin>>choice; switch(choice) {case'1': for(i=0;i<100;i++)//随机产生字符 {array[i]='a'+rand()%26; cout<<setw(2)<<array[i]; file1.put(array[i]);//字符读入exe1.txt文件中 curtime_front_Sender=time(NULL);//时钟运行 }tag=1; file1.close(); cout<<"字符已读入exe1.txt文件中."<<endl; break; case'2': if(tag==1) {cout<<"文件exe1.txt中有新字符到来."<<endl; cout<<"输入Ack:接收字符\n"; cout<<"输入NAk:放弃字符\n"; do { cin.ignore(); cin.getline(str,4); if(strcmp(str,"Ack")==0) { file1.open("exe1.txt",ios::in|ios::out|ios::app); file1.get(ch); while(!file1.eof()) {file3.put(ch); curtime_rear_Receiver=time(NULL); if(curtime_rear_Receiver-curtime_front_Receiver>1)//超时是否判断 {curtime_front_Receiver=time(NULL); continue; }file2<<"接收该字符."; file1.get(ch); }cout<<"文件读写完毕.\n"; } elseif(strcmp(str,"NAk")==0) cout<<"已经放弃这些字符.\n"; elseif(strcmp(str,"NAk")!=0&&strcmp(str,"Ack")!=0) cout<<"输入错误,请从新输入:"<<endl; }while(strcmp(str,"NAk")!=0&&strcmp(str,"Ack")!=0); }elseif(tag==0) cout<<"文件exe1.txt中没有新字符到来."<<endl; break; default:cout<<"谢谢使用."<<endl; } }while(choice!='3'); file1.close();file2.close();file3.close(); } 3.模拟实验,运行源程序. 实验中的问题及心得:通过实验发现在课程学习中对很多方面只是一知半解,并没有深入的加以研究,致使在组织源程序过程中遇到了很多麻烦,例如对ARQ协议只是片面地了解,对其背景,发展过程,应用过程,作用范围并不是很了解,今后一定会在这方面加强认识。通过学习实践发现计算机网络这门课程虽然大部分都是理论课程,很少有实践类的,但其从当今最前沿的计算机科学理论成果出发,将整个网络世界的总体框架呈现在面前,使得网络协议描述表现的淋漓尽致,今后必将以百倍的热情投入到这门课程的学习中。 总结通过实验所掌握的内容: 1.连续ARQ协议的算法#defineMAX_SEQ7/*应该为2^n-1*/typedefenum{frame_arrival,cksum_error,timeout,network_layer_ready}event_type;#includeprotocal.hstaticbooleanbetween(seq_nra,seq_nrb,seq_nrc){/*如果b落在a和c之间(含a不含c)返回true,否则返回false.*/if(((a<=b)&&(b<c))||((c<a)&&(a<=b))||((b<c)&&(c<a)))return(true);elsereturn(false);}staticvoidsend_data(seq_nrframe_nr,seq_nrframe_expected,packetbuffer[]){/*构造和发送数据帧frames;/*起始变量*/=buffer[frame_nr];/*插入分组到帧中*/s.seq=frame_nr;/*插入序号到帧中*/s.ack=(frame_expected+MAX_SEQ)%(MAX_SEQ+1)/*捎带应答*/to_physical_layer(&s);/*传送该帧*/start_timer(frame_nr);}/*启动定时器*/voidprotocal5(void){seq_nrnext_frame_to_send;/*MAX_SEQ>1;用于外出流*/seq_nrack_expected;/*还没有得到应答的最早的帧*/seq_nrframe_expected;/*进入流期望的下一帧*/framer;/*初始变量*/packetbuffer[MAX_SEQ+1]/*外出流的缓存*/seq_nrnbuffered;/*当前正在使用的输出缓存*/event_typeevent;enable_network_layer();/*允许network_layer_ready事件*/ack_expected=0;/*下一个期望进入的应答*/next_frame_to_send=0;/*下一个要送出的帧*/frame_expected=0;/*期望进入的帧的序号*/nbuffered=0;/*初始没有分组被缓存*/while(true){wait_for_event(&event);/*四种可能的事件,见上面event_type定义*/switch(event){ casenetwork_layer_ready;/*网络层有一个分组要发送*//*接收,保存,以及发送一个新的帧*/from_network_layer(&buffer[next_frame-to_send]);/*获得一个新的分组*/nbuffered=nbuffered+1;/*增加发送方的窗口*/send_data(next_frame_to_send,frame_expected,buffer);/*发送帧*/inc(next_frame_to_send);/*发送方的窗口上界向前移动*/ break;caseframe_arrival:/*一个数据帧或控制帧到达*/from_physical_layer(&r);/*从物理层得到一个进入的帧*/if(r.seq==frame_expected){/*所有的帧只能按序接收.*/to_network_layer(&);/*传递分组到网络层*/inc(frame_expected);/*接收方的窗口下界向前移动*/}/*Ackn意味着n-1,n-2,...等.*/while(between(ack_expected,r.ack,next_frame_to_send)){/*处理捎带应答*/nbuffered=nbuffered+1;/*减少一个缓存的帧*/stop_timer(ack_expected);/*帧完好到达,停止定时器*/inc(ack_expected);/*压缩发送窗口*/}break; casecksum_err:break;/*丢弃坏帧*/casetime_out:/*重传所有超时的帧*/next_frame_to_send=ack_expected;/*开始重传*/for(i=1;i<=nbuffered;i++){send_data(next_frame_to_send,fram_expected,buffer);/*重发1帧*/inc(next_frame_to_send);/*准备发送下一帧*/}}if(nbuffered<MAX_SEQ)enable_network_layer();elsedisable_network_layer();}}连续ARQ协议采用的重要原理:在简单停止等待协议的基础上,允许连续发送若干帧,在收到相应ACK后继续发送若干帧,用以提高传输效率。这时ACK及NAK也必须有对应的帧序号,才能够一一对应起来。在发生差错时丢弃原已发送的所有后续帧,重发差错发生以后的所有帧,相当于完全返回重传。信道较差时传输效率不高。连续重发请求ARQ方案是指发送方可以连续发送一系列信息帧,即不用等前一帧被确认便可继续发送下一帧,效率大大提高。但在这种重发请求方案中,需要在发送方设置一个较大的缓冲存储空间(称作重发表),用以存放若干待确认的信息帧。当发送方到对某信息帧的确认帧后,便可从重发表中将该信息帧删除。所以,连续重发请求ARQ方案的链路传输效率大大提高,但相应地需要更大的缓冲存储空间。在这一协议中,当发送站点发送完一个数据帧后,不是停下来等待应答帧,而是可以连续在发送若干个数据帧。如果在此过程中又收到了接收端发来的应答帧,那么还可以接着发送数据帧。由于减少了等待时间,整个通信的吞吐量就提高了。如结点A向结点B发送数据帧,当结点A发完0号帧时,并不等待,而是继续发送后续的1号帧、2号帧等。由于连续发送了许多帧,所以应答帧不仅要说明是对哪一帧进行确认或否认,而且应答帧本身也必须编号。假设2号帧出了差错,于是结点B发送否认帧NAK2。当否认帧NAK2到达结点A时,结点A正在发送5号数据帧。当5号帧发送完毕后,结点A才能进行2号帧的重发。这里要注意两点:接受端只能按序接收数据帧。对于2号帧,结点B应答了NAK2,虽然接着又收到了三个正确的数据帧,但都必须将他们丢弃,因为这些帧的发送序号都不是顺序号;结点A在重传2号数据帧时,虽然已经发完了5号帧,但仍必须向回走,从2号帧起进行重传。正因如此,连续ARQ又称为Go-back-NARQ,意思是当出现差错必须重传时,要向回走N个帧,然后再开始重传。GO-DACK-N策略的基本原理是,当接收方检测出失序的信息帧后,要求发送方重发最后一个正确接收的信息帧之后的所有未被确认的帧;或者当发送方发送了N个帧后,若发现该N帧的前一个帧在计时器超时后仍未返回其确认信息,则该帧被判为出错或丢失,此时发送方就不得不重新发送出错帧及其后的N帧。这就是GO-DACK-N(退回N)法名称的由来。因为对接收方来说,由于这一帧出错,就不能以正常的序号向它的高层递交数据,对其后发送来的N帧也可能都不能接收而丢弃。GO-DACK-N法操作过程如图7
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 上海市金山区华东师大三附中2013-2014学年高一下学期期末考试数学试题
- 【全程复习方略】2020年人教A版数学理(福建用)课时作业:第三章-第八节应-用-举-例
- 学校的八年级的班级工作计划范文
- 陕西省渭南市2025届高三教学质量检测(Ⅰ)物理试题(含答案)
- 四川省绵阳市绵阳中学2024-2025学年高一上学期期末模拟测试物理试题(含答案)
- 【备战2021高考】全国2021届高中英语试题汇编(第六期-11月):U单元-重庆
- 【名师一号】2022届高三历史一轮复习调研试题:第七单元-古代中国经济的基本结构与特点7-13a
- 【走向高考】2021届高三生物二轮复习专项检测:专题4-第3讲-变异、育种与生物进化
- 一年级数学计算题专项练习汇编
- 【名师一号】2020-2021学年苏教版化学检测题-选修五:专题3
- 《格林童话》课外阅读试题及答案
- “销售技巧课件-让你掌握销售技巧”
- 2019北师大版高中英语选修一UNIT 2 单词短语句子复习默写单
- 房地产项目保密协议
- 2023年云南省初中学业水平考试 物理
- 【安吉物流股份有限公司仓储管理现状及问题和优化研究15000字(论文)】
- 火灾自动报警系统施工及验收调试报告
- 《13464电脑动画》自考复习必备题库(含答案)
- 中国成人血脂异常防治指南课件
- 2023塔式太阳能热发电厂集热系统设计规范
- 消费税改革对商贸企业的影响与对策
评论
0/150
提交评论