日期:2014-05-16  浏览次数:20810 次

再问定时器-setitimer问题
#include   <stdio.h>
#include   <time.h>
#include   <sys/time.h>
#include   <stdlib.h>
#include   <signal.h>

bool   bTimeOver   =   false;

void   set_timer()
{
                struct   itimerval   itv,   oldtv;
                itv.it_value.tv_sec   =   5;
                itv.it_value.tv_usec   =   0;
                itv.it_interval.tv_sec   =   0;   //只执行一次
                itv.it_interval.tv_usec   =   0;
               
                setitimer(ITIMER_PROF,&itv,oldtv);  
}

void   sigalrm_handler(int   sig)
{
                bTimeOver   =   true;
                printf( "timer   signal..   %d\n ",   count);
}

void   init_sigaction(void)  
{  
              struct   sigaction   act;  
              act.sa_handler=sigalrm_handler;  
              act.sa_flags=0;  
              sigemptyset(&act.sa_mask);  
              sigaction(SIGPROF,&act,NULL);  
}  

int   main()
{
                init_sigaction();
                set_timer();
                while   (!bTimeOver)
                {}
                exit(0);
}

这是通用的处理定时器的程序,请各位测试一些,时间到是bTimeOver   =   true,但为什么在main函数中调不出while循环?

在跟踪的时候发现定时器到时bTimeOver   会被置位true,但是就是跳不出while循环,请问是那个地方的问题,还是setitimer的用法没有对,请大家测试一下这个程序是否是我说的一样?再次恳求高手测试一下,给我指点。


------解决方案--------------------
SIGALRM属于“不可靠信号”,进程每次处理信号后,就将对信号的响应设置为默认动作;因此,用户如果不希望这样的操作,那么就要在信号处理函数结尾再一次调用signal(),重新安装该信号。


/*
* testtimer.c - test linux timer
*
*/
/*
* 下面是关于setitimer调用的一个简单示范,在该例子中,每隔一秒发出一个SIGALRM,每隔0.5秒发出一个SIGVTALRM信号
* 此函数的问题,如果在sigroutine中的printf中没有 '\n ',函数无法正常运行,怀疑和缓冲区有关
*/
#include <stdio.h>
#include <unistd.h>
#include <sys/signal.h>
#include <sys/time.h>


void sigroutine(int signo){
printf( "Catch a signal -- SIGALRM %d \n ", signo);
signal(SIGALRM, sigroutine);
return;
}

int main()
{
struct itimerval value1, ovalue;

printf( "process id is %d \n ", getpid());

signal(SIGALRM, sigroutine);

value1.it_value.tv_sec = 0;
value1.it_value.tv_usec = 200000;
value1.it_interval.tv_sec = 0;
value1.it_interval.tv_usec = 200000;
setitimer(ITIMER_REAL, &value1, &ovalue);

for(;;)
;

}