Linux网络编程中,UDP协议是如何工作的?

Linux网络编程中,UDP(用户数据报协议)是一种无连接的传输层协议,适用于对数据传输延迟要求较高、但可靠性要求相对较低的场景,如实时音视频传输和在线游戏,以下是关于Linux UDP网络编程的详细解释:

Linux网络编程中,UDP协议是如何工作的?插图1

UDP通信流程

UDP通信过程分为服务器端和客户端两部分,具体步骤如下:

服务器端

1、创建套接字:使用socket()函数创建一个用于UDP通信的套接字。

2、绑定地址:将套接字绑定到本地IP地址和端口号,使用bind()函数。

3、接收数据:使用recvfrom()函数等待并接收来自客户端的数据报。

4、发送数据:使用sendto()函数将数据报发送回客户端。

5、关闭套接字:通信结束后,使用close()函数关闭套接字。

客户端

1、创建套接字:使用socket()函数创建一个用于UDP通信的套接字。

2、发送数据:使用sendto()函数向服务器发送数据报。

Linux网络编程中,UDP协议是如何工作的?插图3

3、接收数据:使用recvfrom()函数等待并接收来自服务器的数据报。

4、关闭套接字:通信结束后,使用close()函数关闭套接字。

UDP编程示例代码

以下是一个简单的UDP客户端和服务器端的代码示例:

UDP服务器端 udpServer.cpp

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <arpa/inet.h>
int main(){
    int server_socket = socket(AF_INET, SOCK_DGRAM, 0);
    if (server_socket == -1) {
        perror("socket");
        exit(EXIT_FAILURE);
    }
    struct sockaddr_in server_addr, client_addr;
    server_addr.sin_family = AF_INET;
    server_addr.sin_port = htons(8888);
    server_addr.sin_addr.s_addr = INADDR_ANY;
    if (bind(server_socket, (struct sockaddr*)&server_addr, sizeof(server_addr)) == -1) {
        perror("bind");
        close(server_socket);
        exit(EXIT_FAILURE);
    }
    char buffer[1024];
    socklen_t client_addr_len = sizeof(client_addr);
    while (1) {
        int n = recvfrom(server_socket, buffer, sizeof(buffer), 0, (struct sockaddr*)&client_addr, &client_addr_len);
        if (n == -1) {
            perror("recvfrom");
            close(server_socket);
            exit(EXIT_FAILURE);
        }
        buffer[n] = ' ';
        printf("Received from client: %s
", buffer);
        char message[] = "Hello, client!";
        sendto(server_socket, message, strlen(message), 0, (struct sockaddr*)&client_addr, client_addr_len);
    }
    close(server_socket);
    return 0;
}

UDP客户端 udpClient.cpp

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <arpa/inet.h>
int main() {
    int client_socket = socket(AF_INET, SOCK_DGRAM, 0);
    if (client_socket == -1) {
        perror("socket");
        exit(EXIT_FAILURE);
    }
    struct sockaddr_in server_addr;
    server_addr.sin_family = AF_INET;
    server_addr.sin_port = htons(8888);
    inet_pton(AF_INET, "127.0.0.1", &(server_addr.sin_addr));
    char message[] = "Hello, server!";
    sendto(client_socket, message, strlen(message), 0, (struct sockaddr*)&server_addr, sizeof(server_addr));
    char buffer[1024];
    socklen_t server_addr_len = sizeof(server_addr);
    int n = recvfrom(client_socket, buffer, sizeof(buffer), 0, (struct sockaddr*)&server_addr, &server_addr_len);
    if (n == -1) {
        perror("recvfrom");
        close(client_socket);
        exit(EXIT_FAILURE);
    }
    buffer[n] = ' ';
    printf("Received from server: %s
", buffer);
    close(client_socket);
    return 0;
}

广播与组播的区别及实现

广播主要用于局域网内的多台计算机通信,而组播则适用于更广泛的网络环境,两者的主要区别在于:

广播:IP地址由网络号+主机号构成,主机标识部分全为1(即*.*.*.255结尾),只能在局域网中使用,客户端需要绑定服务使用的端口才能收到广播消息。

组播:可以用于局域网和广域网,客户端需要加入多播组才能接收到多播数据。

广播代码实现流程

1、创建套接字:使用socket()函数创建一个用于UDP通信的套接字。

Linux网络编程中,UDP协议是如何工作的?插图5

2、设置广播属性:使用setsockopt()函数设置套接字的广播属性。

3、创建广播地址:使用inet_pton()函数创建一个广播地址。

4、发送数据:使用sendto()函数向广播地址发送数据。

5、接收数据:使用recvfrom()函数接收来自客户端的数据。

6、关闭套接字:通信结束后,使用close()函数关闭套接字。

UDP是一种无连接的传输协议,适用于对数据传输延迟要求较高、但可靠性要求相对较低的场景,通过Linux下的Socket编程接口,可以方便地实现UDP通信,广播和组播是UDP通信中的两种重要方式,分别适用于不同的网络环境和需求。

小伙伴们,上文介绍linux网络编程 udp的内容,你了解清楚吗?希望对你有所帮助,任何问题可以给我留言,让我们下期再见吧。

本文来源于互联网,如若侵权,请联系管理员删除,本文链接:https://www.9969.net/84352.html

小末小末
上一篇 2024年10月25日 11:31
下一篇 2024年10月25日 11:52

相关推荐