UDP单播

CMakeLists.txt文件中添加如下行:

link_libraries(ws2_32)

1.发送端

cpp 复制代码
#include <iostream>
#include <winsock2.h>
#include <cstdio>

#pragma comment(lib, "Ws2_32.lib")  // Link with ws2_32.lib

int main() {
     1.Initialize winsock
    WSADATA wsaData;
    int iResult = WSAStartup(MAKEWORD(2, 2), &wsaData);
    if (iResult != NO_ERROR) {
        wprintf(L"WSAStartup failed with error: %d\n", iResult);
        return 1;
    }

     2.Create a socket for sending data
    SOCKET SendSocket = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
    if (SendSocket == INVALID_SOCKET) {
        wprintf(L"socket failed with error: %1d\n", WSAGetLastError());
        WSACleanup();
        return 1;
    }

     3.Set up the RecvAddr structure with the IP address of the receiver (in this example case "192.168.1.1")
     and the specified port number.
    sockaddr_in RecvAddr = {0};
    unsigned short Port = 27015;
    RecvAddr.sin_family = AF_INET;
    RecvAddr.sin_port = htons(Port);
    RecvAddr.sin_addr.s_addr = inet_addr("127.0.0.1");

     4.Send a datagram to the receiver
    wprintf(L"Sending a datagram to the receiver...\n");
    char sendBuf[1024]="Hello";
    int BufLen = 1024;
    iResult = sendto(SendSocket, sendBuf, BufLen, 0, reinterpret_cast<SOCKADDR *>(&RecvAddr), sizeof(RecvAddr));
    if (iResult == SOCKET_ERROR) {
        wprintf(L"sendto failed with error: %d\n", WSAGetLastError());
        closesocket(SendSocket);
        WSACleanup();
        return 1;
    }

     5.When the application is finished sending, close the socket.
    wprintf(L"Finished sending. Closing socket. \n");
    iResult = closesocket(SendSocket);
    if (iResult == SOCKET_ERROR) {
        wprintf(L"closesocket failed with error: %d\n", WSAGetLastError());
        WSACleanup();
        return 1;
    }

     6.Clean up and quit.
    wprintf(L" Exiting.\n");
    WSACleanup();
    return 0;
}

2.接收端代码

cpp 复制代码
#include <iostream>
#include <winsock2.h>
#include <cstdio>

#pragma comment(lib, "Ws2_32.lib")  // Link with ws2_32.lib

int main() {
     1.Initialize winsock
    WSADATA wsaData;
    int iResult = WSAStartup(MAKEWORD(2, 2), &wsaData);
    if (iResult != NO_ERROR) {
        wprintf(L"WSAStartup failed with error: %d\n", iResult);
        return 1;
    }

     2.Create a receiver socket to receive datagrams
    SOCKET RecvSocket = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
    if (RecvSocket == INVALID_SOCKET) {
        wprintf(L"socket failed with error: %1d\n", WSAGetLastError());
        return 1;
    }

     3.Bind the socket to any address and the specified port.
    sockaddr_in RecvAddr = {0};
    unsigned short Port = 27015;
    RecvAddr.sin_family = AF_INET;
    RecvAddr.sin_port = htons(Port);
    RecvAddr.sin_addr.s_addr = htonl(INADDR_ANY);

    iResult=bind(RecvSocket,reinterpret_cast<SOCKADDR*>(&RecvAddr), sizeof(RecvAddr));
    if (iResult != 0) {
        wprintf(L"bind failed with error: %d\n", WSAGetLastError());
        return 1;
    }

     4.Call the recvfrom function to receive datagrams on the bound socket.
    wprintf(L"Receiving datagrams...\n");
    char RecvBuf[1024];
    int RecvAddrSize=sizeof(RecvAddr);
    iResult = recvfrom(RecvSocket, RecvBuf, sizeof(RecvBuf), 0, reinterpret_cast<SOCKADDR *>(&RecvAddr), &RecvAddrSize);
    if (iResult == SOCKET_ERROR) {
        wprintf(L"recvfrom failed with error: %d\n", WSAGetLastError());
    } else{
        printf("%s\n",RecvBuf);
    }

     5.Close the socket when finished receiving datagrams
    wprintf(L"Finished receiving. Closing socket. \n");
    iResult = closesocket(RecvSocket);
    if (iResult == SOCKET_ERROR) {
        wprintf(L"closesocket failed with error: %d\n", WSAGetLastError());
        WSACleanup();
        return 1;
    }

     6.Clean up and quit.
    wprintf(L" Exiting.\n");
    WSACleanup();
    return 0;
}

执行结果:

相关推荐
咩咦16 小时前
C++学习笔记28:静态成员应用:不用循环求1到n的和
c++·学习笔记·类和对象·static·构造函数·oj·静态成员
EllinY16 小时前
CF2217E Definitely Larger 题解
c++·笔记·算法·构造
筠筠喵呜喵17 小时前
Linux软件开发性能优化
linux·c++·性能优化
仰泳之鹅17 小时前
【物联网】使用MQTTX与OneNET云平台进行模拟MQTT协议通信
网络·物联网
Bruce_kaizy17 小时前
c++ linux环境编程——文件io介绍以及open 、write 、read 三剑客深度详解
linux·服务器·c++·ubuntu·操作系统·文件io
宋浮檀s19 小时前
应急响应——恶意流量&攻击行为识别
linux·运维·网络·网络安全·应急响应
yychen_java19 小时前
6G移动通信:当网络开始“思考”与“感知”
网络·人工智能
PAK向日葵19 小时前
我用 C++ 写了一个轻量级 Python 虚拟机,刚刚开源
c++·python·开源
玖釉-19 小时前
下一个排列:从字典序到原地算法的完整推导
数据结构·c++·windows·算法
枕星而眠20 小时前
数据结构八大排序详解(一):四大简单排序
c语言·数据结构·c++·后端