如何在循环(C)中等待2种类型的事件?
作者:互联网
我试图在waitpid()和read()中等待一个真正的循环.具体来说,我正在等待这两个事件中的任何一个,然后在循环的每次迭代中处理它.目前,我有以下实现(这不是我想要的).
while (true) {
pid_t pid = waitpid(...);
process_waitpid_event(...);
ssize_t sz = read(socket, ....);
process_read_event(...);
}
该实现的问题在于第二事件的处理取决于第一事件的完成.我不想按顺序处理这两个事件,而是希望处理循环的每次迭代中首先出现的事件.我该怎么做?
解决方法:
如果您不想触摸线程,可以将其包含在waitpid调用的选项中:
pid_t pid = waitpid(pid, &status, WNOHANG);
从waitpid的联机帮助页:
WNOHANG – return immediately if no child has exited.
因此,如果waitpid没有准备好,它将不会阻塞,程序将继续前进到下一行.
至于读取,如果它是阻塞的,你可能想看看poll(2).你基本上可以检查你的套接字是否在每个设定的时间间隔内就绪,例如250ms,然后调用read.这将使它不会阻止.
您的代码可能看起来像这样:
// Creating the struct for file descriptors to be polled.
struct pollfd poll_list[1];
poll_list[0].fd = socket_fd;
poll_list[0].events = POLLIN|POLLPRI;
// POLLIN There is data to be read
// POLLPRI There is urgent data to be read
/* poll_res > 0: Something ready to be read on the target fd/socket.
** poll_res == 0: Nothing ready to be read on the target fd/socket.
** poll_res < 0: An error occurred. */
poll_res = poll(poll_list, 1, POLL_INTERVAL);
这只是假设您正在从套接字读取,从代码中的变量名称判断.正如其他人所说,你的问题可能需要像线程一样更重要的东西.
标签:c-3,linux,events,concurrency,condition-variable 来源: https://codeday.me/bug/20190623/1266701.html