setitimer

http://blog.csdn.net/muge0913/article/details/7337616

setitimer:和alarm相似,但可以更精确的控制进程。which表示计时方式。value和oldvalue是指向itmerval指针。setitimer()调用成功返回0,否则返回-1。


which取值:

ITIMER_REAL : 以系统真实的时间来计算,它送出SIGALRM信号。

ITIMER_VIRTUAL : 以该进程在用户态下花费的时间来计算,它送出SIGVTALRM信号。

ITIMER_PROF : 以该进程在用户态下和内核态下所费的时间来计算,它送出SIGPROF信号。


itimerval在linux2.6.39/include/linux/time.h中实现。

[cpp] view plain copy print ?
  1. struct itimerval {  
  2.   
  3. struct timeval it_interval; /* timerinterval */  
  4.   
  5. struct timeval it_value; /* currentvalue */  
  6.   
  7. };  


 

itimerval结构中的it_value是减少的时间,当这个值为0的时候就发出相应的信号了. 然后再将it_value设置为it_interval值.

 

 

注:

Linux信号机制基本上是从Unix系统中继承过来的。早期Unix系统中的信号机制比较简单和原始,后来在实践中暴露出一些问题,因此,把那些建立在早期机制上的信号叫做"不可靠信号",信号值小于SIGRTMIN(SIGRTMIN=32,SIGRTMAX=63)的信号都是不可靠信号。这就是"不可靠信号"的来源。它的主要问题是:进程每次处理信号后,就将对信号的响应设置为默认动作。在某些情况下,将导致对信号的错误处理;因此,用户如果不希望这样的操作,那么就要在信号处理函数结尾再一次调用signal(),重新安装该信号。



实例如下:

[cpp] view plain copy print ?
  1. #include <stdio.h>   
  2. #include <sys/time.h>   
  3. #include <signal.h>   
  4. void func(int signumber);  
  5. void main()  
  6. {  
  7.      structitimerval value;  
  8.      signal(SIGALRM,&func);  
  9.   
  10.      value.it_value.tv_sec= 1;  
  11.      value.it_value.tv_usec= 0;  
  12.      value.it_interval.tv_sec= 1;  
  13.      value.it_interval.tv_usec= 0;  
  14.   
  15.      setitimer(ITIMER_REAL,&value,NULL);  
  16.      while(1)  
  17.          pause();  
  18.   
  19. }  
  20.   
  21. void func(int signumber)//signumber是系统向此函数传递的信号编号   
  22. {  
  23.      switch(signumber)  
  24.      {  
  25.          caseSIGALRM:  
  26.               printf("getSIGALRM\n");  
  27.               signal(SIGALRM,&func);  
  28.               break;  
  29.          default:  
  30.               printf("nothing\n");  
  31.               break;  
  32.      }  
  33. }  

setitimer_第1张图片

 

你可能感兴趣的:(setitimer)