C++使用UDP通讯的实现示例

 更新时间:2023年12月20日 14:56:51   作者:沈跃泉  
本文实现对C++使用UDP做了简单封装,实现通讯,包括服务端和客户端,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

对C++使用UDP做了简单封装,可直接运行

头文件udp.h

#pragma once
#include <Winsock.h>
#pragma comment(lib,"WS2_32.lib")

#define LOCAL_IP_ADDR      INADDR_ANY      //当前应用程序接收的IP地址
#define LOCAL_PORT         9527            //当前应用程序的端口

#define DEST_IP_ADDR       "127.0.0.1"     //目标应用程序的IP地址
#define DEST_PORT          9526            //目标应用程序的端口

class UDP
{
public:
	UDP();
	~UDP();
	void setLocalSockAddr(unsigned long localAddr, const int localPort);  //设置当前应用程序的IP地址和端口
	void setDestSockAddr(const char* destAddr, const int destPort);       //设置目标应用程序的IP地址和端口
	int sendData(char* buf, int len);
	int recvData(char* buf, int len);

private:
	WSADATA m_wsaData;
	SOCKET m_Socket;
	sockaddr_in m_localSockAddr; //当前应用程序的sockaddr_in结构体
	sockaddr_in m_destSockAddr;  //目标应用程序的sockaddr_in结构体
};

源文件udp.cpp

#include "udp.h"

UDP::UDP()
{
	WSAStartup(MAKEWORD(2, 2), &m_wsaData);
	m_Socket = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);

	//将socket设为非阻塞模式
	u_long mode = 1;
	ioctlsocket(m_Socket, FIONBIO, &mode);

	//设置当前程序和目标程序的配置
	setLocalSockAddr(LOCAL_IP_ADDR, LOCAL_PORT);
	setDestSockAddr(DEST_IP_ADDR, DEST_PORT);
}

UDP::~UDP()
{
	closesocket(m_Socket);
	WSACleanup();
}

//设置当前应用程序的IP地址和端口
void UDP::setLocalSockAddr(unsigned long localAddr, const int localPort)
{
	//当前应用程序的配置
	m_localSockAddr.sin_family = AF_INET;
	m_localSockAddr.sin_addr.s_addr = htonl(localAddr);
	m_localSockAddr.sin_port = htons(localPort);
	//绑定当前应用程序套接字
	bind(m_Socket, (SOCKADDR*)&m_localSockAddr, sizeof(m_localSockAddr));
}

//设置目标应用程序的IP地址和端口
void UDP::setDestSockAddr(const char * destAddr, const int destPort)
{
	//目标应用程序的配置
	m_destSockAddr.sin_family = AF_INET;
	m_destSockAddr.sin_addr.s_addr = inet_addr(destAddr);
	m_destSockAddr.sin_port = htons(destPort);
}

int UDP::sendData(char * buf, int len)
{
	int ret = sendto(m_Socket, buf, len, 0, (SOCKADDR*)&m_destSockAddr, sizeof(m_destSockAddr));
	return ret;
}

int UDP::recvData(char* buf, int len)
{
	int sockAddrSize = sizeof(sockaddr_in);
	int ret = recvfrom(m_Socket, buf, len, 0, (SOCKADDR*)&m_localSockAddr, &sockAddrSize);
	return ret;
}

使用示例

程序1

#include <iostream>
#include "udp.h"

int main()
{
	UDP udp;
	while (1)
	{
		char buf[1024];
		int ret = udp.recvData(buf, 1024);
		if (ret > 0)
		{
			std::cout << "server recv: " << buf << std::endl;
		}
		else
		{
			std::cout << "server recv: " << "recv failed" << std::endl;
		}
		Sleep(1000);
	}

	return 0;
}

程序2

需要先将udp.h中宏定义的IP和端口修改一下

#define LOCAL_IP_ADDR      INADDR_ANY      //当前应用程序接收的IP地址
#define LOCAL_PORT         9527            //当前应用程序的端口

#define DEST_IP_ADDR       "127.0.0.1"     //目标应用程序的IP地址
#define DEST_PORT          9526            //目标应用程序的端口
#include <iostream>
#include "udp.h"

int main()
{
	UDP udp;
	while (1)
	{
		char buf[1024] = "hello udp...";
		udp.sendData(buf, 1024);
		std::cout << "client send: " << buf << std::endl;
		Sleep(1000);
	}
	
	return 0;
}

程序运行效果

将两个程序一起打开,可以看到运行结果

在这里插入图片描述

在这里插入图片描述

到此这篇关于C++使用UDP通讯的实现示例的文章就介绍到这了,更多相关C++ UDP通讯内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C++深入分析数据在内存中的存储形态

    C++深入分析数据在内存中的存储形态

    使用编程语言进行编程时,需要用到各种变量来存储各种信息。变量保留的是它所存储的值的内存位置。这意味着,当您创建一个变量时,就会在内存中保留一些空间。您可能需要存储各种数据类型的信息,操作系统会根据变量的数据类型,来分配内存和决定在保留内存中存储什么
    2023-01-01
  • C++标准库中sstream与strstream的区别详细解析

    C++标准库中sstream与strstream的区别详细解析

    以下是对C++标准库中sstream与strstream的区别进行了详细的分析介绍,需要的朋友可以过来参考下
    2013-09-09
  • C语言实现随机抽取纸牌程序

    C语言实现随机抽取纸牌程序

    这篇文章主要为大家详细介绍了C语言实现随机抽取纸牌程序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • C语言回溯法 实现组合数 从N个数中选择M个数

    C语言回溯法 实现组合数 从N个数中选择M个数

    在平时的算法的题目中,时常会遇到组合数相关的问题,暴力枚举。在N个数中挑选M个数出来。利用for循环也可以处理,但是可拓展性不强,于是写这个模板供以后参考
    2018-08-08
  • C语言如何计算一个整数的位数

    C语言如何计算一个整数的位数

    这篇文章主要介绍了C语言如何计算一个整数的位数,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • C++图形界面开发Qt教程:嵌套圆环示例

    C++图形界面开发Qt教程:嵌套圆环示例

    这篇文章主要介绍了C++实现图形界面开发Qt教程,涉及坐标函数的应用及图形界面程序设计,需要的朋友可以参考下,希望能给你带来帮助
    2021-08-08
  • c++选择排序详解

    c++选择排序详解

    选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理是每一次从无序组的数据元素中选出最小(或最大)的一个元素,存放在无序组的起始位置,无序组元素减少,有序组元素增加,直到全部待排序的数据元素排完。
    2017-05-05
  • c++11&14-智能指针要点汇总

    c++11&14-智能指针要点汇总

    这篇文章主要介绍了c++11&14-智能指针的要点,文中代码非常详细,供大家学习和参考,感兴趣的朋友可以了解下
    2020-06-06
  • 基于epoll的多线程网络服务程序设计

    基于epoll的多线程网络服务程序设计

    这篇文章主要为大家详细介绍了基于epoll的多线程网络服务程序设计,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08
  • C语言入门篇--理解地址及内存

    C语言入门篇--理解地址及内存

    本篇文章是基础篇,适合c语言刚入门的朋友,本文主要介绍了c语言的内存及地址,帮助大家快速入门c语言的世界,更好的理解c语言
    2021-08-08

最新评论