实现rip路由选择协议

本文档详细介绍了如何实现RIP路由选择协议。首先,数据存储在data.txt文件中,描述了N1到N7网络间的路由器连接。接着,定义了Route类来存储数据,Routelists类存储路由表项,Network类则包含了路由表的操作,如读取文件、显示路由表、初始化、更新和保存。在Network类中,通过特定的成员函数执行距离向量算法,实现路由表的更新和展示。最后,主函数调用这些功能进行实际操作。
摘要由CSDN通过智能技术生成

简介

在data.txt中存有一条链路,共有N1-N7个网络,其中有6个路由器R1-R6。其内容如下:

N1 R1 N2

N2 R2 N3

N3 R3 N4

N4 R4 N5

N5 R5 N6

N6 R6 N7

在代码文件中定义Route类进行存储data.txt中的数据信息。定义Routelists进行存储每一个路由表的一个表项(目标地址,距离,下一跳地址)。

定义一个Network类,含有记录路由表的数组变量,在类中包含了所要进行的一系列操作。

在其析构函数中,读入文件data.txt中的数据并保存在Network的成员变量中。

通过show()函数进行显示路由表的信息。

通过bgroutes()函数进行初始化路由表,由初始数据可以知道与某个路由器链接的是哪些网络,则会得到初始路由表(目的网络 目的 下一跳地址)。

通过change()函数进行对相邻路由表的距离加1,并把下一跳的地址改为路由名字。

通过chang2()将原路由表中改变后的路由表变回来。

update函数是核心代码,进行距离向量算法的具体实现:

通过falg进行记录要修改的路由表的类型。首先默认其值为1,即是要求改的路由表中未有的一项,则需要进行直接添加。其次在将要修改的路由表的每一条记录与该路由表中原记录中的每一个值相比较,若目的网络相同则比较其下一跳的地址,如果下一跳地址相同,则修改为现在的距离;如果下一跳地址不同,则进行按照两项的距离进行比较,将距离小的一项替换掉距离大的一项。

UPDATE()函数进行更新后的路由表的信息的显示。

save()函数进行信息文件的保存。

流程图

定义类

1.     route类

  成员变量:route:结点路由器

               net_r:路由器相连右网络

                   net_l:路由器相连右网络

2.     Routelists类

成员变量:net:目标网络

          distance:距离

          next_route:下一跳地址

3.     Network类

私有成员变量:tiao[20]:每个路由表的表项有多少

公有成员变量:Routelistsrts[20][20],tmp[20];

              Route rt[20];    

成员函数:Network()析构函数,用于读入数据

          show()显示相关路由表的信息

          bgroutes()初始化路由表

          change()用于是路由表中距离加1,得到新的路由表

          chan

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值