- 1、本文档共20页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
RIP路由算法通信实例
RIP路由算法通信实例
//MY_RIP_TextA.cpp
#include stdio.h
#include stdlib.h
#include winsock2.h
#pragma comment(lib, ws2_32.lib)
#define SEND_LENGTH 5000
#define RECV_LENGTH 5000
#define A 4
#define B 6
typedef struct route_info{
int intent_net;
int distance;
int next_route;
struct route_info* next;
}ROUTE_INFO;
int menu();
void init_route(ROUTE_INFO* head);
int update_route(ROUTE_INFO* head);
void select_route(ROUTE_INFO* head);
void free_linked_list(ROUTE_INFO* head);
void route_to_char(ROUTE_INFO* head,char route_infor[]);
void char_to_route(ROUTE_INFO* head,char route_infor[]);
void RIP_algorithm(ROUTE_INFO* head,ROUTE_INFO* recv);
void main()
{
int menu_value;
ROUTE_INFO* head;
head = (ROUTE_INFO*)malloc(sizeof(ROUTE_INFO));
head-next_route=A;
head-next=NULL;
while(1)
{
menu_value = menu();
switch(menu_value)
{
case 1:
init_route(head);
break;
case 2:
update_route(head);
break;
case 3:
select_route(head);
break;
case 4:
exit(0);
break;
default:
printf(输入菜单选项有误,请重新输入.);
break;
}
}
free_linked_list(head);
}
int menu()
{
int i=0;
printf(***************路由器R4***************\n);
printf(** 1.录入初始路有路由信息。 **\n);
printf(** 2.更新路由信息。 **\n);
printf(** 3.查询路由信息。 **\n);
printf(** 4.exit。 **\n);
printf(**************************************\n);
scanf(%d,i);
return i;
}
void init_route(ROUTE_INFO* head)
{
ROUTE_INFO* route_info;
ROUTE_INFO* p=head;
char c;
while(1)
{
route_info = (ROUTE_INFO*)malloc(sizeof(ROUTE_INFO));
p-next=route_info;
p=p-next;
p-next=NULL;
printf(请输入目的网络、距离、下一跳路由器:);
scanf(%d,p-intent_net);
scanf(%d,p-distance);
scanf(%d,p-next_route);
scanf(%c,c);
printf(是否继续y/n:);
scanf(%c,c);
if(c==y||c==Y);
else if(c==n||c==N)
break;
/*
printf(%d ,p-intent_net);
printf(%d ,p-distance);
printf(%d \n,p-next_route);*/
}
}
int update_route(ROUTE_INFO* head)
{
WORD socketVersi
文档评论(0)