中南大学计算机网络实验概述.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
中南大学 计算机网络实验报告 姓名: 学号: 班级: 实验一 分槽ALOHA协议仿真实验 【实验目的】 掌握VB、VC++、VS或JAVA等集成开发环境编写仿真程序的方法; 理解并掌握分槽ALOHA协议原理。 【实验内容】 编写仿真程序,对一定网络环境下MAC层的多路访问协议的分槽ALOHA协议进行实现。通过仿真,学习协议采取的介质访问管理,包括介质分配和冲突解决机制,并对协议的性能与理论结果进行比较分析。 【实验具体设计】 1.实验流程图 2. 关键代码说明: 此仿真实验中一共包括三个类。分别是Send.java、Pot.java、AlohaTest.java。在这三个类中,Pot中随机产生站点发送数据包的时间。Send根据站点发送的时间,判断是否发生冲突。如果发生冲突,则重发。 部分关键代码: 重发的时间的选择: for(int i=1;i6;i++){//当发生冲突的时候,重传,选择重发的时间 while (al.get(0)==al.get(i)){ al.set(i, rnd.nextInt(10)); //compare(); } }public void cycle(){ int sum = a+b+c+d+e; for(;sum=100;){ sum = a+b+c+d+e; change(); } } 实验截图 【实验设备与实验环境】 实验设备:联想E430 实验环境:win7家庭版,使用eclipse编写。 【实验总结】 通过这次实验,更加了解了分槽ALOHA协议的内容。学习了协议采用的介质访问管理。对于协议的性能有了更加深刻的理解。在实验中,曾遇到不少困难。但是通过老师与同学们的帮助都一一解决。这个ALOHA实验的比较简单。但是真实情况下的要复杂许多。并没有完全模拟出来。而且程序有些冗余。还需提高代码的编写能力。 【源代码】(java编写) package alohalx_check; public class AlohaTest { public static void main(String[] args){ /*1.对于站点的初始化。一共有 五个站点。 * 需要写一个关于站点的类。这个类里面包括随机发送数据包。 *2.需要对每个站点随机发送数据包的时间进行判断。如果一样,则两个都需要重发。如果不一样,则继续发送下一个数据包。 * 直到五个站点发送数据包的总数为100000。即需要对总的数据包数目计数。并且在控制台输出每一个站点数据包的发送情况。 * */ Send s1 = new Send(); //s1.change(); s1.cycle(); //s1.init(); } } package alohalx_check; import java.util.Random; public class Pot { /*1.可以随机发送数据包。 * 2.随机发送的时间 * */ private int time; Random rnd = new Random(); public void setTime(){ time = rnd.nextInt(10); } public int getTime(){ return this.time; } } package alohalx_check; import java.util.ArrayList; import java.util.Random; public class Send {//设置槽长为1,使用信道的时间为10.五个站点进行发送 ArrayList al = new ArrayList(); int a = 0; int b = 0; int c = 0; int d = 0; int e = 0; Random rnd = new Random(); public void compare(){//在change中调用 for(int n=1;n=5;n++){ for(int m=1;m=5;m++){ if(n!=m){ if(al.get(n)==al.get(m)){ al.set(n, 10); al.set(m, 10); } } } } } public void

文档评论(0)

金不换 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档