UDP时间更新服务程序

2023-12-26 09:48
文章标签 更新 时间 udp 服务程序

本文主要是介绍UDP时间更新服务程序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

UDP时间更新服务程序


 http://qzher.com/?p=647


网络编程,最好采用两台电脑,

或者一台电脑,再开个虚拟机,虚拟机采用网络桥接模式

 

 

特点:

发消息方一直向指定IP发送报时消息

收方一上线就能得到发来的即时消息 (未上线的消息全被抛弃)

若收方上线期间发消息方关闭收方也一直等待发消息方的消息,

只要发消息方一上线发送消息,收方可以继续接收发来的消息

 

应用比如视频直播,游戏画面等的传输 

 

 

 


 

源码:

 

 

#include <stdio.h>

#include<iostream>

#include <Winsock2.h>

#include <time.h>

#pragma comment(lib,"ws2_32.lib")

#define  BUF_SIZE 64

 

int main()

{

WSADATA wsadata;

int nRes = 0;

nRes = WSAStartup(MAKEWORD(2, 3), &wsadata);

if (0 != nRes)

{

return 0;

}

 

SOCKET sockSend;

sockSend = socket(AF_INETSOCK_DGRAMIPPROTO_UDP);

if (INVALID_SOCKET == sockSend)

{

WSACleanup();

return 0;

}

 

sockaddr_in addrRecv;

addrRecv.sin_family = AF_INET;

addrRecv.sin_port = htons(9090);

// 向222的IP发送数据

addrRecv.sin_addr.S_un.S_addr = inet_addr("192.168.1.222");

 

// 就算绑定错误也不用管(这里应该也会绑定出错)

nRes = bind(sockSend, (sockaddr*)&addrRecvsizeof(sockaddr_in));

printf("—-时间服务器已启动—–\n ");

 

int nSendLen = 0;

struct tm tLocal;

time_t  t = time(NULL);

char chTime[64];

int nLen = sizeof(sockaddr_in);

 

while (true)

{

// 获取当前时间并格式化

t = time(NULL);

localtime_s(&tLocal, &t);

sprintf_s(chTime"%s"asctime(&tLocal));

 

// 向222发送时间

nSendLen = sendto(sockSendchTimestrlen(chTime), 0, (sockaddr*)&addrRecvnLen);

Sleep(1000);

}

 

closesocket(sockSend);

WSACleanup();

std::cout << "server stoped! " << std::endl;

 

return 0;

}

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

#include <stdio.h>

#include<iostream>

#include <Winsock2.h>

#pragma comment(lib,"ws2_32.lib")

#define  BUF_SIZE 64

 

int main()

{

WSADATA wsadata;

int nRes = 0;

nRes = WSAStartup(MAKEWORD(2, 2), &wsadata);

if (0 != nRes)

{

return 0;

}

 

SOCKET sockTimeRecv;

sockTimeRecv = socket(AF_INETSOCK_DGRAMIPPROTO_UDP);

if (INVALID_SOCKET == sockTimeRecv)

{

WSACleanup();

return 0;

}

 

sockaddr_in addrRecv;

addrRecv.sin_family = AF_INET;

addrRecv.sin_port = htons(9090);

addrRecv.sin_addr.S_un.S_addr = htonl(INADDR_ANY);

 

nRes = bind(sockTimeRecv, (sockaddr*)&addrRecvsizeof(sockaddr_in));

 

 

char chBufRecv[BUF_SIZE] = { "0" };

int nLen = sizeof(sockaddr_in);

printf("—-qzher.com start to recv data—–\n ");

 

charpChClientAddr = nullptr;

int nRecvLen = 0;

 

while (true)

{

nRecvLen = recvfrom(sockTimeRecvchBufRecvBUF_SIZE, 0,

(sockaddr*)&addrRecv, &nLen);

 

if (strlen(chBufRecv) > 0)

{

pChClientAddr = inet_ntoa(addrRecv.sin_addr);

printf("%s send:———%s\n"pChClientAddrchBufRecv);

}

}

 

closesocket(sockTimeRecv);

WSACleanup();

std::cout << "server stoped! " << std::endl;

 

return 0;

}


源码下载: (VS2015)  http://download.csdn.net/detail/sinat_35523212/9615378

这篇关于UDP时间更新服务程序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/538961

相关文章

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

poj3468(线段树成段更新模板题)

题意:包括两个操作:1、将[a.b]上的数字加上v;2、查询区间[a,b]上的和 下面的介绍是下解题思路: 首先介绍  lazy-tag思想:用一个变量记录每一个线段树节点的变化值,当这部分线段的一致性被破坏我们就将这个变化值传递给子区间,大大增加了线段树的效率。 比如现在需要对[a,b]区间值进行加c操作,那么就从根节点[1,n]开始调用update函数进行操作,如果刚好执行到一个子节点,

hdu1394(线段树点更新的应用)

题意:求一个序列经过一定的操作得到的序列的最小逆序数 这题会用到逆序数的一个性质,在0到n-1这些数字组成的乱序排列,将第一个数字A移到最后一位,得到的逆序数为res-a+(n-a-1) 知道上面的知识点后,可以用暴力来解 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#in

hdu1689(线段树成段更新)

两种操作:1、set区间[a,b]上数字为v;2、查询[ 1 , n ]上的sum 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<queue>#include<set>#include<map>#include<stdio.h>#include<stdl

hdu 1754 I Hate It(线段树,单点更新,区间最值)

题意是求一个线段中的最大数。 线段树的模板题,试用了一下交大的模板。效率有点略低。 代码: #include <stdio.h>#include <string.h>#define TREE_SIZE (1 << (20))//const int TREE_SIZE = 200000 + 10;int max(int a, int b){return a > b ? a :

AI行业应用(不定期更新)

ChatPDF 可以让你上传一个 PDF 文件,然后针对这个 PDF 进行小结和提问。你可以把各种各样你要研究的分析报告交给它,快速获取到想要知道的信息。https://www.chatpdf.com/

GIS图形库更新2024.8.4-9.9

更多精彩内容请访问 dt.sim3d.cn ,关注公众号【sky的数孪技术】,技术交流、源码下载请添加微信:digital_twin123 Cesium 本期发布了1.121 版本。重大新闻,Cesium被Bentley收购。 ✨ 功能和改进 默认启用 MSAA,采样 4 次。若要关闭 MSAA,则可以设置scene.msaaSamples = 1。但是通过比较,发现并没有多大改善。

JavaFX应用更新检测功能(在线自动更新方案)

JavaFX开发的桌面应用属于C端,一般来说需要版本检测和自动更新功能,这里记录一下一种版本检测和自动更新的方法。 1. 整体方案 JavaFX.应用版本检测、自动更新主要涉及一下步骤: 读取本地应用版本拉取远程版本并比较两个版本如果需要升级,那么拉取更新历史弹出升级控制窗口用户选择升级时,拉取升级包解压,重启应用用户选择忽略时,本地版本标志为忽略版本用户选择取消时,隐藏升级控制窗口 2.

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

记录每次更新到仓库 —— Git 学习笔记 10

记录每次更新到仓库 文章目录 文件的状态三个区域检查当前文件状态跟踪新文件取消跟踪(un-tracking)文件重新跟踪(re-tracking)文件暂存已修改文件忽略某些文件查看已暂存和未暂存的修改提交更新跳过暂存区删除文件移动文件参考资料 咱们接着很多天以前的 取得Git仓库 这篇文章继续说。 文件的状态 不管是通过哪种方法,现在我们已经有了一个仓库,并从这个仓