gpt4 book ai didi

`recvfrom` 函数可以用来检查之前是否有数据发送到套接字?还是需要积极倾听?

转载 作者:太空狗 更新时间:2023-10-29 15:34:49 25 4
gpt4 key购买 nike

我有一个 while(1)使用 recvfrom 的循环获取已从另一个进程 (P2) 发送到域套接字的数据。

while 循环需要做两件事,首先监听来自 P2 的传入数据,其次运行另一个函数 checkVoltage() .

所以它运行起来有点像这样:

while(true)
{
listenOnSocket() /*listens for 100 u seconds*/
checkVoltage();
}

我的问题是:listenOnSocket()函数使用 recvfrom函数来检查来自另一个进程的输入。它花费 100usecs 监听,然后超时并继续运行 checkVoltage()功能。所以它花费了 99% 的时间在 listenOnSocket() 中功能。我的问题是,如果 P2 在 checkVoltage() 期间向套接字发送信息函数,那么它将导致错误,指出:sending datagram message: No such file or directory .

有没有办法让这个循环检查之前发送到套接字的任何数据?这样,如果 P2 在 checkVoltage() 期间发送数据函数,它不会导致错误。

谢谢。

编辑:

所以 listenOnSocket()函数创建一个名称为 FireControl 的套接字当我运行 P1(从 P2 接收数据的程序)时 FireControl文件消失了一瞬间然后重新出现。如果 P2 在此短时间内向 P1 发送数据,则会导致上面提到的错误。

所以我想这意味着我应该将套接字的创建与 recvfrom 分开函数,因为在创建新套接字的短时间内它不存在 - 如果这有意义的话。

我是个笨蛋,我一开始就应该把它们分开!

EDIT2:这里是 listenOnSocket() :

command listenOnSocket(int timeout, float utimeout) /*Returns null payload when no input is detected*/
{
command payload;
int sock;
socklen_t* length;
struct sockaddr_un name;
char buf[1024];

struct timeval tv;
tv.tv_sec = timeout;
tv.tv_usec = utimeout;

/* Create socket from which to read. */
sock = socket(AF_UNIX, SOCK_DGRAM, 0);
if (sock < 0)
{
perror("opening datagram socket");
payload = nullPayload;
}

/* Create name. */
name.sun_family = AF_UNIX;
strcpy(name.sun_path, NAME);

unlink(name.sun_path);

/* Bind the UNIX domain address to the created socket */
if (bind(sock, (struct sockaddr *) &name, sizeof(struct sockaddr_un)))
{
perror("binding name to datagram socket\n");
payload = nullPayload;
}

/*Socket has been created at NAME*/
if (timeout != 0 || utimeout != 0)
{
setsockopt(sock, SOL_SOCKET, SO_RCVTIMEO, (char *)&tv, sizeof(struct timeval));
}
else
{
tv.tv_sec = 0;
tv.tv_usec = 0;
setsockopt(sock, SOL_SOCKET, SO_RCVTIMEO, (char *)&tv, sizeof(struct timeval));
}
/* Read from the socket */
if (recvfrom(sock, &payload, sizeof(command), 0, (struct sockaddr *)&name, &length) < 0) /*Less than zero results from a timeout*/
{
payload = nullPayload;
}

unlink(NAME);
return payload;
}

这是调用它的循环:

while (1)
{
buffer = getADCValue();

checkVoltage();

temp = listenOnSocket(0, 100); /*Look for a new command*/
doStuffWithTempIfItHasChanged();
}
}

最佳答案

I guess this means I should separate the creation of the socket from the recvfrom function, because the short period where the new socket is created it does not exist

没错。如果您每次在 listenOnSocket() 套接字中打开和关闭套接字,(a) 您将丢失任何您未读取的已排队的数据报,以及 (b) 在套接字处于发送状态时发送关闭将失败......当然。没有什么可以发送给他们的。

关于 `recvfrom` 函数可以用来检查之前是否有数据发送到套接字?还是需要积极倾听?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39988609/

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