1

我正在尝试研究信号处理程序是如何工作的。我编写了代码,每 100 微秒触发一次警报信号。但是,没有发出信号。这是代码:

 #include <signal.h>
 #include <ucontext.h>
 #include <sys/time.h>
 #include<unistd.h>
 #include<setjmp.h>
 #include<stdio.h>

void handler(int signum, siginfo_t *ptr, ucontext_t *old_context)
{
    printf("inside handler");
}

int main()
{
 struct itimerval itv;
 struct sigaction act;
 act.sa_handler = handler;
 act.sa_flags=SA_RESTART|SA_SIGINFO;
 sigaction(SIGVTALRM, &act, 0);
 itv.it_interval.tv_sec=0;
 itv.it_interval.tv_usec=100;
 itv.it_value.tv_sec = 0;
 itv.it_value.tv_usec = 100;          

 setitimer(ITIMER_VIRTUAL, &itv, NULL); //engage timer
 int i=0;
 while(i<=100)
 {
    printf("main\n");
    i++;
 }  
}

有人可以解释我做错了什么吗?

谢谢

4

1 回答 1

2

您的循环运行时间可能不到 100us,试试这个:

volatile int i=0;
while(i<=100000000)
{
    //printf("main\n");
    i++;
}

我删除了 printf 以使输出不会被淹没,并使 i volatile 使编译器不会优化循环。

于 2011-09-18T05:13:30.567 回答