recvfrom 中的分段错误(已创建核心转储)

segmentation fault(core dump created) in recvfrom

我正在编写一个简单的 C 代码来创建一个监听套接字。代码如下:

#include <stdio.h>
#include <string.h>
#include <sys/socket.h>
#include <netinet/ip.h>

void main() {
    struct sockaddr_in server;
    struct sockaddr_in client;
    int clientlen;
    char buf[1500];

    int sock = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);

    memset((char *)&server, 0, sizeof(server));
    server.sin_family = AF_INET;
    server.sin_addr.s_addr = htonl(INADDR_ANY);
    server.sin_port = htons(9090);

    if(bind(sock, (struct sockaddr *) &server, sizeof(server)) < 0)
        error("ERROR on binding");

    while(1) {
        bzero(buf, 1500);
        recvfrom(sock, buf, 1500-1, 0, (struct sockaddr *) &client, &clientlen);
        printf("%s\n", buf);
        printf("%d - %s\n", client.sin_port, client.sin_addr.s_addr);
    }
    close(sock);
}

代码编译没有问题,但是当我使用 netcat 通过客户端连接到服务器时:

nc -u 10.0.2.4 9090

然后我发送了一些消息,消息得到回复,然后我收到错误消息。有人知道我为什么会出现这种行为吗? 谢谢。

这里有两个主要问题。首先,在调用 recvfrom 之前,clientlen 应该包含地址结构的大小,但它是未初始化的。所以设置如下:

int clientlen = sizeof(client);

其次,您正在使用 %s 打印 client.sin_addr.s_addr 但该字段不是字符串。您应该使用 inet_ntoastruct inaddr_t 转换为字符串:

printf("%d - %s\n", ntohs(client.sin_port), inet_ntoa(client.sin_addr));