ImageVerifierCode 换一换
格式:DOCX , 页数:18 ,大小:97.87KB ,
资源ID:14840450      下载积分:2 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bingdoc.com/d-14840450.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(计算机网络课设 计算校验和汇总.docx)为本站会员(b****5)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

计算机网络课设 计算校验和汇总.docx

1、计算机网络课设 计算校验和汇总学生姓名林娟班级学号1103050401专 业计算机科学与技术课程设计题目 计算校验和评语组长签字:成绩日期 2012 年 12 月3日课程设计任务书学 院信息科学与工程学院专 业计算机科学与技术学生姓名林娟班级学号1103050401课程设计题目计算校验和实践教学要求与任务: 本课程设计的主要意图是,通过计算机网络中的计算校验和来了解计算机是怎么样判断接收数据的正确与错误。同时也让我们更进一步的了解计算机的一般思想,从而了解计算校验和的目的与作用。最后我们要学会计算校验和,了解和扩展计算机网络的知识面。校验和的作用就是保证数据传送的正确性。本次课程设计的主要内容

2、包括以下几个方面:课程设计目的,通过这一点我们可以了解我们为什么要计算校验和,它的作用和目的是什么,从而学会计算校验和。课程设计的要求,根据下面课程设计中的计算方法编制程序为给定数据计算检验和。计算校验和的相关知识,如交换性与结合性,字节顺序的自主性,并行计算以及实例,以及给出一些编码技术可以提高校验和的速度。课程设计分析,主要是从数据的输入方式,校验和的计算流程图。工作计划与进度安排:第15周星期一:设计任务分析和总体设计星期二:软件算法和流程设计星期三:软件编码实现星期四:软件总体调试星期五:交课程设计报告、答辩、验收程序指导教师: 2012 年12月 日专业负责人:2012 年 12 月

3、 日学院教学副院长:2012 年 12月 日 摘 要7 实验体会.131 课程设计目的网络上的信号最终,都是通过物理传输进行传输线路进行传输的,如果高层没有采用差错控制,那么物理层传输的数据信号是可能有差错的。为了保证数据的正确性,在物理层的基础,计了数据层。设计数据链路层的主要作用就是在原始的、有差错的线路改进成逻辑上无差错的数据链路,以向网络层提供高质量的服务。本课程设计主要通过一个简单例子使学生了解网络协议中校驵和的计算过程,以及设置校验和的作用。 目前,进行了差错检测和差错控制的主要方法是:在需要传输的数据分组后面加上一定的冗余信息通常都是通过对所发送的数据应用某种算法进行计算而得到的

4、。数据的接收方在接收到数据后进行同样的计算再与收到的冗余信息进行比较不,如果结果不同说明出现了差错,此时可以要求发送方重传该组数据,以此达到保证数据准确性的目的。 在普通使用的网络协议中都设置了校验和项以保存冗余信息,例如IPV4、ICMPV4、IGMPV4、ICMPV6、UDP 和TCP等等。计算校验和算法称为网际协议和算法,简单来说,就是把被校验的数据按16位进行累加,然后取反码。若数据字节长度为奇数,则在数据尾部补一个字节的0以凑成偶数。关于计算更详细的信息请参考RFC1071。2 课程设计要求根据前面介绍的算法,编制程序为给定数据计算校验和。(1)、以命令行形式运行:check_sum

5、 infile其中check_sum为程序名,infile为输入数据文件名。 (2)、输出:数据文件的校验和。3.相关知识3.1校验和的概念 网络上的数据最终都是通过物理传输线路进行传输的,如果高层没有采用差错控制,那么物理层传输的数据的正确性,在物理层的基础上设计了数据链路,以向网络层提高质量的服务。 目前,进行差错检测和控制的主要方法是发送方在需要发送的数据后面增加一定的冗余信息,这些冗余信息通常是通过对发送的数据进行某种算法计算而得到的。接收方对接收数据进行同样的计算,然后与数据后面附加的冗余信息进行比较,如果比较结果不同就说明在传输中出现了差错,并要求发送方重新传送该数据,以此达到确保

6、数据准确性的目的。在普通使用的网络协议(例如IP,ICMP,IGMP,UDP与TCP等)中,通常都设置了校验和字段以保存这些冗余信息。计算这些校验和的算法称为网络校验和算法,就是将被校验的数据按16位进行累加,然后取反码,如果数据字节长度为奇数,则数据尾部补一个字节的0以凑成偶数。关于计算校验和算法的详细信息请参考。计算校验和(1) 交换性与结合性因为校验和主要考虑被校验数据中所包含字节数量的是奇数还是偶数,所以校验和的计算可以以任意顺序进行,甚至可以把数据进行分组后再计算。例如,用A、B、C、D,Y,Z分别表示一系列八位组,用a,b这样形式的字节来表示a*256+b的整数,那么16位校验和就

7、可以通过以下形式给出:A,B+C,D+Y,Z 1A,B+C,D+Z,0 2在这里,+代表1补数加法,即将前面的16位校验和按位取反。1可以以(A,B+C,D+J,0+(0,K+Y,Z) 3的形式进行计算。(2) 字节顺序的自主性打破被校验数据中的字节顺序仍可以计算出正确的16位校验和。例如,我们交换字节组中两字节的顺序,得到B,A+D,C+Z,Y 4所得到的得结构与1式是相同的(当然结果也是要进行一次反转的)。为什么会是这样呢?我们发现两种顺序获得的进位是相同的,都是从第15位到第0位进位以及从第7位到第8位进位。这也就是说,交换字节位置只是改变高低位字节的排列顺序,但并没有改变它们的内在联系

8、。因此,无论底层的硬件设置中对字节的接收顺序如何,校验和都可以被准确地校验出来。例如,假设校验和是以主机序(高位字节在前低位字节在后)计算的数据帧,但以网络序(低位字节在前高位字节在后)存放在内存中。每一个16位的字中的字节在传送过程中都交换了顺序,在计算校验和之后仍会先交换位置再存入内存,这样就与接受到的原本以网络序存储的数据帧中的校验和项保持一致了。(3)并进行计算某些机器的字处理长度是16位的倍数,这样可以提高它的计算速度。由于加法所具有的结合性,我们没有必要按照顺序对每个字节进行累加。相反,我们可以利用这一特点对它们进行并行累加。并行地计算校验和只是增加了每次累加的信息长度。例如,在一

9、个323位的机器上,我们可以一次增加4个字节,即A,B,C,D+。计算结束后再把累加和“折叠”起来,把一个32位的数值变为16位,这样产生的新的进位也要循环累积起来。此外,在此仍不考虑字节顺序的问题,我们可以用D,C,B,A+或B,A,D,C+;这样的顺序来计算校验和,最终再通过交换16位校验和中的字节序来得到正确的值。这些改变顺序的方法都是为了让所有的偶数字节进入一个校验和字节,所有的奇数字节进入一个校验和字节。3.3 示例下面将通过一个简单的例子来演示通过上述的几种方法所得到的校验和的情况16位按字节累加“正常”顺序交换顺序字节0/1:00 0100010100字节2/3:f2 03F20

10、303f2字节4/5:f4 f5f4f5f5f4字节6/7:f6 f7f6f7f7f6- -合计1:2dc 1f02ddf01f2dcdc f0ddf0f2dc进位:1 221- -合计2:dd f2ddf2f2dd最终结果:dd f2ddf2dd f232位按字节累加“正常”顺序交换顺序字节0/1/2/3:0001f203010003f203f20100字节4/5/6/7:f4f5f6f7f5f4f7f6f7 f6 f5f4-合计1:0f4f7e8fa0f6f4fbe80fbe8f6f4进位:000前半段:f4f7f6f4fbe8后半段:e8fafbe8f6f4-合计2:1ddf11f2dc

11、1f2dcddf1f2dcf2dc进位:111-合计3:ddf2f2ddf2dd最终结果:ddf2ddf2ddf2还有一个例子是把计算工作分为两组,第二组是以奇数边界起始的。按字节累加“正常”顺序字节0/1:00 010001字节2/:f2 (00)f200- -合计:f2 01f201字节4/5:03 f403f4字节6/7:f5 f6f5f6字节8/:f7 (00)f700- -合计2:1f0ea合计2:f0ea进位:1-合计3:f0eb合计1:f201合计3(交换字节序):ebf0-合计41ddf1合计4ddf1进位:1-合计5:ddf23.4 一些编码技术可以提高校验和的计算速度(1)

12、延迟进位法这种方法在主要的累加循环结束之后再把进位累加进和值。其实现方式就是用32位的累加器获得16位校验和,这样溢出就产生在高16位上。这种方法避免了累加器中进位传感器机构的设置,但是它要求的容量是原来的累加器容量的两倍,因此它更多地依赖于硬件条件。(2)反向循环法这种方法可以减少由循环而产生的负荷,有效地展开内部的累加循环,把循环过程中的一系列加法命令复制下来。这种技术通常可以节省大量的时间,但是程序的逻辑设计会比较复杂。(3)合并数据拷贝法计算校验和以及读入数据都需要将数据从内存的一个位置转移到另一个位置,这样会占用内存总线的带宽,而内存总线的传输效率是提高校验和计算速度的瓶颈,尤其是对

13、于某些机器(如一些简单的慢速的微型机)来说,这一问题尤为严重。为了解决这个问题,可以把数据读入的过程与校验的过程合二为一,也就是在读入数据的同时计算校验和,这样就可以省去一次数据移动的过程,从而提高校验和的计算速度。4 课程设计分析校验和的计算过程主要分为三个步骤:数据文件的输入,校验和的计算和校验结果的输出。其中,主要的是数据的输入和校验和的计算过程。4.1 数据的输入方式输入数据可能是以字符形式存储的,而校验和的计算则要采用数据形式,所以在从文件读取数据时,都要进行字符到数据的相互转换。1) 将读入的ASCII码转化为相应的整型变量。if(ch=0&=a&ch=A&ch0xff|lowby

14、t化e0xff)0 /高8位或低8位中的任何一方产生了溢出(进位) lowbyte+=(highbyte8); /低字节加上高字节超过8位的进位 highbyte=highbutr&0xff; /清除高字节的进位 highbyte+=(lowbyte8); /高字节加上来自低字节的进位 lowbyte=lowbyte&0xff; Count /清除低字节的进4.3 程序流程图图2-1给出了一个流程的参考方案4.4 相关扩展前面我们提到,校验和还有其他一些计算方法,下面我们就来简要介绍以下利用延迟进位法进行计算的方法。延迟进位法的算法描述:将进位累加的过程延迟到整个累加循环结束之后进行,这样可以

15、提高计算速度。3.1 主要的实现过程while(!infile.eof() /判断文件是否结束,若否则对被校验的16位数据进行累加 int h, 1; /分别表示16位数据的高8位和低8位 infilehexh; /从文件中读入一个16进制表示的数据,作为高8位 if(infile.eof() l=0; /若后面没有其他数据,将0作为低8位 else infilehex1; /若后面还有数据,读入下一个作为低8位 sum+=(h*256+l); /将组合好的16位数据累加到sum中infile.close(); /关闭文件check_sum=short(sum&0xffff)+(sum16);

16、 /将32位累加和转换为16位数据/若累加过程中有向高16位的进位,则要将进位部分加到低16位上check_sum=-check_sum; /对累加和取反码 5 程序代码#include#includevoid main(int arga, char *argb)/指针数组作为主函数参数,用于函数带参数入/定义并初始化变量 FILE *fp; char ch; unsigned char r1,r2; unsigned int count=0,checksum=0,rp=0; unsigned long int sum=0; /打开文件argb1 if(fp=fopen(d:jiaoyan.t

17、xt,r)=NULL) printf(nn File cant be opened); exit(1); printf(nnthe type of output:data-sumnn); /从txt文件读取字符,并进行数据处理 while(1) if(ch=etc(ft)!=EOF) count+; if(ch!= ) if(count%12=0) printf(n); /将字符转换成相应的整形变量 if(ch=0&ch=a&ch=A&ch=F) ch=ch-A+10; /计算8字节数的累加值,将奇数位累加到长整形sum的158位,偶数位累加到低80位 /这样就避免了数据个数为奇偶的处理操作

18、if(count%2=1) r2=ch4; else r1=ch&0x0f; rp=r2|r1; if(count%4=2) sum+=rp16) checksum=(long(sum16)+long(sum&0x0000ffff); checksum=checksum&0x0000ffff; /结果输出 printf(nnsum:%lx-checksum:%x,sum,checksum); printf(nnsource:arga=%d,targb=%sn,arga,argb1); fclose(ft); 6 运行结果与分析(运行结果是否正确,课程设计过程中出现的问题及其解决方案,可扩充的功能及设计等。)7.实验体会 在没触这个实验的时候,根本不懂得怎么运用命令提示符,记事本和本程序相联。此程序让我学会了和多东西,知识是广阔的,我们要懂得去交流,把不会的知识化为己有。谢谢老师。8参考文献1谢希仁 编著. 计算机网络 (第5版) .北京:电子工业出版社,20082吴宜功 吴英 编著. 计算机网络课程设计 (第2版). 北京: 机械工业出版社,2012

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2