- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个 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/
谁能解释当应用程序通过 802.11 WiFi 网络发送 UDP 单播数据报时它是如何工作的?假设非阻塞 UDP 套接字。具体而言,假设 802.11n 或 802.11ac 以及相当新的 Linux
我是一名优秀的程序员,十分优秀!