我正在尝试使用setitimer发送一个SIGALRM,它依次调用我的处理程序函数以打印到stdout。我已经在互联网上搜寻了几个小时,并且没有明确的迹象表明应如何使用setitimer。我尝试了各种组合,但似乎都没有用。在我的代码中,我使用的是套接字和pthreads,但我认为它与问题没有真正的关系,因为我试图通过信号设置警报,但无论如何该信号都会停止所有线程,因此我将代码保留给简单。
void handle_alarm(int sig){
printf("Printing Info\n");
}
int main(int argc, char**argv){
struct itimerval it_val;
signal(SIGALRM, handle_alarm);
it_val.it_value.tv_sec = 1;
it_val.it_value.tv_usec = 1000000;
it_val.it_interval = it_val.it_value;
setitimer(ITIMER_REAL, &it_val, NULL);
while(1){}
return 0;
}
它应该仅每秒打印一次到终端,但不是。谁能给我任何建议?
答案 0 :(得分:0)
有人可以给我任何建议吗?
内核可能!如果系统调用失败,则内核将报告错误代码。 libc将报告发生的错误,并适当设置errno
。因此改变
setitimer(ITIMER_REAL, &it_val, NULL);
到
if (setitimer(ITIMER_REAL, &it_val, NULL) == -1) {
perror("setitimer");
exit(1);
}
,看看出了什么问题。 appropriate man page将包含可能的错误代码及其原因的列表:
EFAULT new_value, old_value, or curr_value is not valid a pointer. EINVAL which is not one of ITIMER_REAL, ITIMER_VIRTUAL, or ITIMER_PROF; or (since Linux 2.6.22) one of the tv_usec fields in the structure pointed to by new_value contains a value outside the range 0 to 999999.
此修复程序是发件人的一项练习。也不要习惯从信号处理程序内部调用非异步信号安全函数!