linux网络编程笔记——UDP
目前这部分代码会出现阻塞问题,暂时尚未解决
#include "udp.h" #include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <unistd.h>
#include <errno.h>
#include <malloc.h> #include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <time.h>
#include <arpa/inet.h> int PrintDiff(diff_t *diff)
{
printf("\n\n-----------------------\n");
printf("tow : %f\n", diff->tow);
printf("numBds: %d\n", diff->numBds);
printf("numGps: %d\n", diff->numGps);
printf("numGln: %d\n", diff->numGln);
int j;
printf("system: ");
for (j = ; j < MAXSAT; ++j)
{
printf("%d ", diff->system[j]);
}
printf("\n"); printf("PRN: ");
for (j = ; j < MAXSAT; ++j)
{
printf("%d ", diff->PRN[j]);
}
printf("\n"); printf("dDO: ");
for (j = ; j < MAXSAT; ++j)
{
printf("%f ", diff->dDO[j]);
}
printf("\n"); printf("dPR: ");
for (j = ; j < MAXSAT; ++j)
{
printf("%f ", diff->dPR[j]);
}
printf("\n"); printf("------------------------------------\n");
} int server_len;
int client_len; #define RECV_LOOP_COUNT 10
int recv_within_time(int fd, char *buf, size_t buf_n,struct sockaddr* addr,socklen_t *len,unsigned int sec,unsigned usec)
{
struct timeval tv;
fd_set readfds;
int i=;
unsigned int n=;
for(i=;i<RECV_LOOP_COUNT;i++)
{
FD_ZERO(&readfds);
FD_SET(fd,&readfds);
tv.tv_sec=sec;
tv.tv_usec=usec;
select(fd+,&readfds,NULL,NULL,&tv);
if(FD_ISSET(fd,&readfds))
{
if((n=recvfrom(fd,buf,buf_n,,addr,len))>=)
{
return n;
}
}
}
return -;
} int rover_sock_fd;/*套接字文件描述符*/
struct sockaddr_in addr_rover_server;
int UdpRoverInit(char *server_ip)
{
char SERVER_IP_ADDRESS[]="127.0.0.1";
strcpy(SERVER_IP_ADDRESS, server_ip); rover_sock_fd = socket(AF_INET,SOCK_DGRAM,);//创建套接子
//初始化服务器端地址
memset(&addr_rover_server,,sizeof(addr_rover_server));
addr_rover_server.sin_family = AF_INET;
addr_rover_server.sin_addr.s_addr = inet_addr(SERVER_IP_ADDRESS);
addr_rover_server.sin_port = htons(SERVER_PORT); server_len = sizeof(struct sockaddr_in);
//printf("begin:\n");
return rover_sock_fd;
} int UdpRoverRecieve(diff_t *diff)
{
int recv_num, i=;
unsigned char recv_buf[MAX_LEN_ONCE];
unsigned char send_buf[MAX_LEN_ONCE]; unsigned char *_dest=malloc(sizeof(diff_t)+MAX_LEN_ONCE);
memset((void *)_dest,,sizeof(diff_t)+MAX_LEN_ONCE); //发送命令
memset(send_buf,,MAX_LEN_ONCE);
strcpy(send_buf,"\nrover_get\n");
//do
sendto(rover_sock_fd,send_buf,MAX_LEN_ONCE,,(struct sockaddr *)&addr_rover_server,server_len);
usleep();
while()
{
recv_num = recv_within_time(rover_sock_fd,recv_buf,MAX_LEN_ONCE,(struct sockaddr *)&addr_rover_server,&server_len,,);
if (recv_num<MAX_LEN_ONCE)
{
continue;
}
if(strncmp(recv_buf,"\nserver_start\n",strlen("\nserver_start\n")))
{
putchar(recv_buf);
printf("@@%d\n", recv_num);
//return 1;
}
else{
printf("good\n");
break;}
} while() {
recv_within_time(rover_sock_fd,recv_buf,MAX_LEN_ONCE,(struct sockaddr *)&addr_rover_server,&server_len,,);
if (!strncmp(recv_buf,"\nserver_end\n",strlen("\nserver_end\n"))) break;
if (!strncmp("\nserver |",recv_buf,strlen("\nserver |")))
{
memcpy(_dest+i*(MAX_LEN_ONCE/),recv_buf+(MAX_LEN_ONCE/),MAX_LEN_ONCE/);
++i;
}
printf(".");
} printf("-------------%d------------\n", i);
if (i!=sizeof(diff_t)/(MAX_LEN_ONCE/)+)
{
printf("%d ,get wrong, will not update this time!\n", i);
}
else{
memcpy((void *)diff, _dest, sizeof(diff_t)+MAX_LEN_ONCE);
if ()
{
PrintDiff(diff);
}
} free(_dest);
UdpClose(rover_sock_fd);
return ;
} int station_sock_fd;
struct sockaddr_in addr_station_server;
int UdpStationInit(char *server_ip)
{
char SERVER_IP_ADDRESS[]="127.0.0.1";
strcpy(SERVER_IP_ADDRESS, server_ip); station_sock_fd = socket(AF_INET,SOCK_DGRAM,);//创建套接子
//初始化服务器端地址
memset(&addr_station_server,,sizeof(addr_station_server));
addr_station_server.sin_family = AF_INET;
addr_station_server.sin_addr.s_addr = inet_addr(SERVER_IP_ADDRESS);
addr_station_server.sin_port = htons(SERVER_PORT); server_len = sizeof(struct sockaddr_in);
printf("begin send:\n"); return ;
}
int UdpStationSend(diff_t *diff)
{
int i=;
int send_num; unsigned char send_buf[MAX_LEN_ONCE];
unsigned char *src = (unsigned char *)diff; memset(send_buf,,MAX_LEN_ONCE);
strcpy(send_buf,"\nstation_start\n");
sendto(station_sock_fd,send_buf,MAX_LEN_ONCE,,(struct sockaddr *)&addr_station_server,server_len); int j;
for (j = ; j < MAX_LEN_ONCE; ++j)
{
putchar(send_buf[j]);
} for(i=;i<sizeof(diff_t)/+;++i)
{
memset(send_buf,,MAX_LEN_ONCE);
strcpy(send_buf,"\nstation|");
memcpy(send_buf+,src+i*(MAX_LEN_ONCE/),MAX_LEN_ONCE/); for (j = ; j < MAX_LEN_ONCE; ++j)
{
putchar(send_buf[j]);
} send_num = sendto(station_sock_fd,send_buf,MAX_LEN_ONCE,,(struct sockaddr *)&addr_station_server,server_len); usleep();
}
printf("---%d----%d----%d----%d----\n", i,sizeof(diff_t),MAX_LEN_ONCE/,sizeof(diff_t)/(MAX_LEN_ONCE/)); memset(send_buf,,MAX_LEN_ONCE);
strcpy(send_buf,"\nstation_end\n");
sendto(station_sock_fd,send_buf,MAX_LEN_ONCE,,(struct sockaddr *)&addr_station_server,server_len); for (j = ; j < MAX_LEN_ONCE; ++j)
{
putchar(send_buf[j]);
} return ;
} int server_sock_fd; //套接子描述符号
struct sockaddr_in addr_server, addr_server_client;
int UdpServerInit()
{
int recv_num;
int send_num; char recv_buf[MAX_LEN_ONCE]; server_sock_fd = socket(AF_INET,SOCK_DGRAM,); if(server_sock_fd < ){
perror("client socket");
exit();
} else{
printf("client sock sucessful\n");
} memset(&addr_server,,sizeof(struct sockaddr_in));
addr_server.sin_family = AF_INET;//协议族
addr_server.sin_port = htons(SERVER_PORT);
addr_server.sin_addr.s_addr = htonl(INADDR_ANY);//任意本地址 client_len = sizeof(struct sockaddr_in); /*绑定套接字*/
if(bind(server_sock_fd,(struct sockaddr *)&addr_server,sizeof(struct sockaddr_in))< ){
perror("server bind");
return -;
} else{
printf("server bind sucess\n");
} return ;
} int UdpServerLoop(diff_t *diff, int arg)
{
int recv_num,send_num, i=;
unsigned char recv_buf[MAX_LEN_ONCE];
unsigned char send_buf[MAX_LEN_ONCE]; unsigned char *dest=malloc(sizeof(diff_t)+MAX_LEN_ONCE);
memset((void *)dest,,sizeof(diff_t)+MAX_LEN_ONCE); unsigned char *src = (unsigned char *)diff;
while()
{
//update diff data
recv_num = recvfrom(server_sock_fd,recv_buf,MAX_LEN_ONCE,,(struct sockaddr *)&addr_server_client,&client_len);
int j;
if(recv_num < ) {
perror("recv_from");
return -;
} //update diff data
if (!strncmp(recv_buf,"\nstation_start\n",strlen("\nstation_start\n")))
{
i=;
while() {
recv_num = recvfrom(server_sock_fd,recv_buf,MAX_LEN_ONCE,,(struct sockaddr *)&addr_server_client,&client_len);
if(recv_num < ) {
perror("recv_from");
return -;
} if (!strncmp(recv_buf,"\nstation_end\n",strlen("\nstation_end\n"))) break;
if (!strncmp("\nstation|",recv_buf,strlen("\nstation|")))
{
memcpy(dest+i*(MAX_LEN_ONCE/),recv_buf+(MAX_LEN_ONCE/),MAX_LEN_ONCE/);
++i;
}
//printf("recv sucessful\n"); } printf("-------------%d------------\n", i);
if (i!=sizeof(diff_t)/(MAX_LEN_ONCE/)+)
{
printf("get wrong, will not update this time!\n");
}
else{
memcpy((void *)diff, dest, sizeof(diff_t)+MAX_LEN_ONCE);
if (arg)
{
PrintDiff(diff);
}
} } //send diff data
if(!strncmp(recv_buf,"\nrover_get\n",strlen("\nrover_get\n")))
{
memset(send_buf,,MAX_LEN_ONCE);
strcpy(send_buf,"\nserver_start\n");
sendto(server_sock_fd,send_buf,MAX_LEN_ONCE,,(struct sockaddr *)&addr_server_client,client_len); //以后要防溢出s
for(i=;i<sizeof(diff_t)/(MAX_LEN_ONCE/)+;++i)
{
strcpy(send_buf,"\nserver |");
memcpy(send_buf+(MAX_LEN_ONCE/),src+i*(MAX_LEN_ONCE/),MAX_LEN_ONCE/);
send_num = sendto(server_sock_fd,send_buf,MAX_LEN_ONCE,,(struct sockaddr *)&addr_server_client,client_len);
if(send_num < ){
perror("sendto");
return -;
} }
memset(send_buf,,MAX_LEN_ONCE);
strcpy(send_buf,"\nserver_end\n");
sendto(server_sock_fd,send_buf,MAX_LEN_ONCE,,(struct sockaddr *)&addr_server_client,client_len);
}
}
return ;
} int UdpClose(int sock_fd)
{
close(sock_fd);
return ;
}
linux网络编程笔记——UDP的更多相关文章
- Linux网络编程笔记(修订版)
我的网络编程笔记, 因为最近又要做Linux下的网络编程,故重新修订, 其中一些内容参考了文末的链接及文章 1. 基本概念 2. 基本接口 2.1. 打开一个socket 2.2. 将 ...
- Linux网络编程:UDP Socket编程范例
TCP协议提供的是一种可靠的,复杂的,面向连接的数据流(SOCK_STREAM)传输服务,它通过三段式握手过程建立连接.TCP有一种"重传确认"机制,即接收端收到数据后要发出一个肯 ...
- python-socket网络编程笔记(UDP+TCP)
端口 在linux系统中,有65536(2的16次方)个端口,分为: 知名端口(Well Known Ports):0-1023,如80端口分配给HTTP服务,21端口分配给FTP服务. 动态端口(D ...
- linux网络编程笔记——TCP
1.TCP和UDP TCP是长连接像持续的打电话,UDP是短消息更像是发短信.TCP需要消耗相对较多的资源,但是传输质量有保障,UDP本身是不会考虑传输质量的问题. 2.网络传输内容 我习惯的做法是直 ...
- Linux网络编程:UDP实现可靠的文件传输
我们知道,用TCP实现文件传输很简单.相对于TCP,因为UDP是面向无连接.不可靠的传输协议,所以我们需要考虑丢包和后发先至(包的顺序)的问题,所以我们想要实现UDP传输文件,则需要解决这两个问题.方 ...
- Linux 网络编程(UDP)
客户端代码 #include<stdio.h> #include<stdlib.h> #include<string.h> #include<sys/sock ...
- Linux网络编程学习路线
转载自:https://blog.csdn.net/lianghe_work/article 一.网络应用层编程 1.Linux网络编程01——网络协议入门 2.Linux网络编程02——无连接和 ...
- linux网络编程-(socket套接字编程UDP传输)
今天我们来介绍一下在linux网络环境下使用socket套接字实现两个进程下文件的上传,下载,和退出操作! 在socket套接字编程中,我们当然可以基于TCP的传输协议来进行传输,但是在文件的传输中, ...
- Linux网络编程10——使用UDP实现五子棋对战
思路 1. 通信 为了同步双方的棋盘,每当一方在棋盘上落子之后,都需要发送给对方一个msg消息,让对方知道落子位置.msg结构体如下: /* 用于发给对方的信息 */ typedef struct t ...
随机推荐
- KMP算法的C++实现
这个问题阮一峰老师讲的很清楚,链接 这里我只贴一下我的C++实现代码: #include <iostream> #include <cstring> #include < ...
- How to learn linux device driver
To learn device driver development, like any other new knowledge, the bestapproach for me is to lear ...
- 在CentOS 6.X 上面安装 Python 2.7.X
在CentOS 6.X 上面安装 Python 2.7.X CentOS 6.X 自带的python版本是 2.6 , 由于工作需要,很多时候需要2.7版本.所以需要进行版本升级.由于一些系统工具和服 ...
- android中getSystemService详解
android的后台运行在很多service,它们在系统启动时被SystemServer开启,支持系统的正常工作,比如MountService监 听是否有SD卡安装及移除,ClipboardS ...
- 使用Quartz创建定时任务
项目开发中经常需要定时循环执行某些任务 比如定时发送报表,定时发送邮件,亦或者定时清理缓存,定时更新数据等等 有些时候可以简单地利用Windows Server的计划任务执行程序 Linux也有相应的 ...
- bzoj2794
这题我得到一个经验,bool型的dp一定要想办法把bool去掉来表示更多的东西(1933也是这个道理) 暴力大家都会,这里有两个限制条件 一个限制条件我们可以排序不断加入,另一个呢 我们可以用f[i] ...
- Linux shell下批量创建缩略图
一.背景 今天,突然发现手机客户端上的最新新闻缩略图都不显示了,上服务器上看了看, 发现新的新闻图片根本没有生成缩略图. 这套新闻发布系统是很老的程序了,查了一下,问题的原因是不支持png格式的图片, ...
- POJ 3177 Redundant Paths (桥,边双连通分量,有重边)
题意:给一个无向图,问需要补多少条边才可以让整个图变成[边双连通图],即任意两个点对之间的一条路径全垮掉,这两个点对仍可以通过其他路径而互通. 思路:POJ 3352的升级版,听说这个图会给重边.先看 ...
- H264码流打包分析(精华)
H264码流打包分析 SODB 数据比特串-->最原始的编码数据 RBSP 原始字节序列载荷-->在SODB的后面填加了结尾比特(RBSP trailing bits 一个bit“1”)若 ...
- java/python中获取当前系统时间,并与字符串相互转换格式,或者转化成秒数,天数等整数
java转换成秒数 Date类有一个getTime()可以换回秒数,例如: public class DateToSecond { public static void main(String[] a ...