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中实现。

  1. struct itimerval {  
  2.   
  3. struct timeval it_interval; /* timerinterval */  
  4.   
  5. struct timeval it_value; /* currentvalue */  
  6.   
  7. };  
struct itimerval {

struct timeval it_interval; /* timerinterval */

struct timeval it_value; /* currentvalue */

};


 

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

 

 

注:

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



实例如下:

  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. }  
#include <stdio.h>
#include <sys/time.h>
#include <signal.h>
void func(int signumber);
void main()
{
     structitimerval value;
     signal(SIGALRM,&func);

     value.it_value.tv_sec= 1;
     value.it_value.tv_usec= 0;
     value.it_interval.tv_sec= 1;
     value.it_interval.tv_usec= 0;

     setitimer(ITIMER_REAL,&value,NULL);
     while(1)
         pause();

}

void func(int signumber)//signumber是系统向此函数传递的信号编号
{
     switch(signumber)
     {
         caseSIGALRM:
              printf("getSIGALRM\n");
              signal(SIGALRM,&func);
              break;
         default:
              printf("nothing\n");
              break;
     }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值