在linux c编程中。setitimer是一个比?经常使用的函数。可用来实现延时和定时的功能,网上有各种零零散散的使用方法说明,都仅仅提到了个别使用方法,抽出时间实践整理了一份比?具体的:
  使用时须要引入的头文件:
  #include <sys/time.h>
  setitimer函数原型:
  int setitimer(int which, const struct itimerval *new_value,
  struct itimerval *old_value);
  当中which?数表示类型。可选的值有:
  ITIMER_REAL:以系统真实的时间来计算,它送出SIGALRM信号。
  ITIMER_VIRTUAL:以该进程在用户态下花费的时间来计算,它送出SIGVTALRM信号。
  ITIMER_PROF:以该进程在用户态下和内核态下所费的时间来计算。它送出SIGPROF信号。
  紧接着的new_value和old_value均为itimerval结构体,先看一下itimerval结构体定义:
  struct itimerval {
  struct timeval it_interval; /* next value */
  struct timeval it_value;    /* current value */
  };
  struct timeval {
  time_t      tv_sec;         /* seconds */
  suseconds_t tv_usec;        /* microseconds */
  };
  itimeval又是由两个timeval结构体组成,timeval包括tv_sec和tv_usec两部分。当中tv_se为秒。tv_usec为微秒(即1/1000000秒)
  当中的new_value?数用来对计时器进行设置,it_interval为计时间隔,it_value为延时时长,以下样例中表示的是在setitimer方法调用成功后,延时1微秒便触发一次SIGALRM信号,以后每隔200毫秒触发一次SIGALRM信号。
  settimer工作机制是,先对it_value,当it_value为零时触发信号。然后重置为it_interval。继续对it_value。一直这样循环下去。
  基于此机制。setitimer既能够用来延时运行,也可定时运行。
  假如it_value为0是不会触发信号的,所以要能触发信号,it_value得大于0;假设it_interval为零,仅仅会延时。不会定时(也是说仅仅会触发一次信号)。
  old_value?数,通经常使用不上。设置为NULL,它是用来存储上一次setitimer调用时设置的new_value值。
  下面是一个简单的使用样例:
#include <stdio.h>
#include <signal.h>
#include <sys/time.h>
void signalHandler(int signo)
{
switch (signo){
case SIGALRM:
printf("Caught the SIGALRM signal! ");
break;
}
}
int main(int argc, char *argv[])
{
signal(SIGALRM, signalHandler);
struct itimerval new_value, old_value;
new_value.it_value.tv_sec = 0;
new_value.it_value.tv_usec = 1;
new_value.it_interval.tv_sec = 0;
new_value.it_interval.tv_usec = 200000;
setitimer(ITIMER_REAL, &new_value, &old_value);
for(;;);
return 0;
}