gpt4 book ai didi

c - OSX 上的 getsockopt 返回不正确的值?

转载 作者:太空宇宙 更新时间:2023-11-04 02:42:38 25 4
gpt4 key购买 nike

我正在使用以下程序来调试一个更大的问题。

现在,如果我在 OSX 上运行相同的程序,getopt 永远不会返回 0 或 1,它总是返回我为 optval 设置的任何值!!

一定是我的程序中有明显的错误在逃避我。

示例我将此程序运行为 ./a.out 64.233.160.105

./a.out 64.233.160.105
getsockopt: Undefined error: 0
getsockopt returned 0 SO_REUSEPORT -> 199
setsockopt reuseport: Undefined error: 0
set ret = 0 SO_REUSEPORT -> 1
setsockopt linger: Undefined error: 0
set ret = 0 SO_LINGER -> 0
getsockopt: Undefined error: 0
getsockopt returned 0 SO_REUSEPORT -> 99
sendto: Undefined error: 0
send to sent 11 bytes

这是我正在使用的示例程序。

/* Sample UDP client */

#include <sys/socket.h>
#include <netinet/in.h>
#include <stdio.h>
#include <unistd.h>
#include <errno.h>
#include <stdlib.h>
#include <memory.h>
#include <arpa/inet.h>

int main(int argc, char **argv)
{
int sockfd, n;
struct sockaddr_in servaddr, cliaddr;
char *sendline = "Hello World";
char recvline[1000];
int ret;
extern int errno;
uint32_t optval;
socklen_t optlen;
struct linger linger_opt;

if (argc != 2) {
printf("usage: udpcli <IP address>\n");
exit(1);
}

sockfd = socket(AF_INET, SOCK_DGRAM, 0);

bzero(&servaddr, sizeof(servaddr));
servaddr.sin_family = AF_INET;
servaddr.sin_addr.s_addr = inet_addr(argv[1]);
servaddr.sin_port = htons(4500);

errno = 0;
optval = 199;
ret = getsockopt(sockfd, SOL_SOCKET, SO_REUSEPORT, &optval,
(socklen_t *) & optlen);
perror("getsockopt");
printf("getsockopt returned %d SO_REUSEPORT -> %d\n", ret, optval);

errno = 0;
optval = 1;
ret = setsockopt(sockfd, SOL_SOCKET, SO_REUSEPORT, &optval, sizeof(optval));
perror("setsockopt reuseport");
printf("set ret = %d SO_REUSEPORT -> %d\n", ret, optval);

errno = 0;
optval = 0;
linger_opt.l_onoff = 0;
linger_opt.l_linger = 0;
ret = setsockopt(sockfd, SOL_SOCKET, SO_LINGER, &linger_opt, sizeof(linger_opt));
perror("setsockopt linger");
printf("set ret = %d SO_LINGER -> %d\n", ret, optval);

optval = 99;
errno = 0;
ret = getsockopt(sockfd, SOL_SOCKET, SO_REUSEPORT, &optval, &optlen);
perror("getsockopt");
printf("getsockopt returned %d SO_REUSEPORT -> %d\n", ret, optval);

errno = 0;
ret = sendto(sockfd, sendline, strlen(sendline), 0,
(struct sockaddr *) &servaddr, sizeof(servaddr));
perror("sendto");
printf("send to sent %d bytes \n",ret);
close(sockfd);
}

最佳答案

最近我遇到了同样的问题。

错误: 罪魁祸首是“sizeof”。 Sizeof 是一个返回常量 int 的运算符,它给出任何给定数据元素的大小。setsockopt 的第五个参数 'socklen_t *optlen' 需要一个 socklen_t 类型的值。尽管 socklen_t 和 int 大多数时候可以互换使用。这样的使用可能会导致难以追踪的错误,就像它在这里所做的那样。

ret = setsockopt(sockfd, SOL_SOCKET, SO_REUSEPORT, &optval, sizeof(optval));

即使 setsockopt 没有返回错误或失败,由于使用了“sizeof(optval)”,套接字选项也从未真正设置过。这就是 getsockopt 无法返回更改值的原因。

修复: 1. 将 optvalue 的大小分配给 optlen。 optlen=sizeof(optval); 2.用 optlen 作为第 5 个参数设置套接字选项。 ret = setsockopt(sockfd, SOL_SOCKET, SO_REUSEPORT, &optval, optlen);

此修复程序在 Linux 上使用 gcc 编译器对我有效。希望对其他人有帮助。

关于c - OSX 上的 getsockopt 返回不正确的值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30276293/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com