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;
}

执行结果:

相关推荐
崎岖Qiu13 小时前
【计算机网络 | 第七篇】数据链路层及三个基本问题
网络·网络协议·计算机网络·数据链路层
科技块儿13 小时前
物联网设备分布分析需要精准地理信息?支持IPv4IPv6双栈批量解析的IP离线库
物联网·网络协议·tcp/ip
Yu_Lijing13 小时前
网络复习篇——网络基础(一)
网络·c++·笔记
Bella的成长园地13 小时前
为什么c++中的条件变量的 wait() 函数需要配合while 循环或谓词?
c++·面试
charlee4413 小时前
为什么现代 C++ 库都用 PIMPL?一场关于封装、依赖与安全的演进
c++·智能指针·raii·pimpl·编译防火墙·封装设计
乾元14 小时前
身份与访问:行为生物识别(按键习惯、移动轨迹)的 AI 建模
运维·网络·人工智能·深度学习·安全·自动化·安全架构
tzy23314 小时前
通俗理解 TCP 的 三次握手 和 四次挥手
网络·tcp/ip·三次握手·四次挥手
MSTcheng.14 小时前
CANN ops-math算子的跨平台适配与硬件抽象层设计
c++·mfc
code monkey.14 小时前
【Linux之旅】Linux 进程间通信(IPC)全解析:从管道到共享内存,吃透进程协作核心
linux·c++·ipc
薛定谔的猫喵喵14 小时前
基于C++ Qt的唐代诗歌查询系统设计与实现
c++·qt·sqlite