我有一个C程序,它每分钟轮询一些硬件传感器一次,并将读数添加到数据库中。为了确保读数更接近分钟(而不是分钟+开销时间),程序创建一个孩子来做实际工作,然后在创建另一个孩子之前休眠60秒。
这就是我一直在尝试的方法:
while(1)
{
/* Create a child to do the work */
if((pid = fork()) < 0)
{
perror("fork");
exit(1);
}
else if(pid > 0)
{
/*parent continues*/
select(0, 0, NULL, NULL, &time);
claim_children();
continue;
}
/*Now in the child*/
process_pvs();
}我还听说select()可以通过执行以下操作来实现我想要的功能:
struct timeval time;
time.tv_sec = 60;
time.tv_usec = 0;
select(0, 0, 0, 0, time);但由于某些原因,这只适用于while循环中的1次迭代。在此之后,程序根本不等待,并不断地创建子程序。
那么,怎样才能最好地让我的程序在不被sigchld中断的情况下做到这一点呢?
发布于 2012-10-08 21:08:36
您可以使用以下命令忽略子信号
signal(SIGCHLD, SIG_IGN);这将停止中断,但您需要注意等待所有的孩子。通常是一个循环来捕获它们。
while(waitpid(-1, &status, WNOHANG) > 0);当然,只有当您不在其他地方创建其他子进程时,这才能很好地工作。
发布于 2012-10-08 21:05:44
您可以简单地围绕它编写代码;检测中断的系统调用,记下时间,并使用逻辑来确定是否需要重新进入睡眠状态,如果需要,持续多长时间。
https://stackoverflow.com/questions/12782303
复制相似问题