1.setitimer函数
setitimer
函数用于设置一个间隔定时器,它会在指定的时间间隔到达时向进程发送一个信号。其定义如下:
#include <sys/time.h>
int setitimer(int which, const struct itimerval *new_value, struct itimerval *old_value);
该函数一共有三个参数,其中:
(1)which
为指定定时器的类型,包括以下三种:
ITIMER_REAL
:定时器基于真实时间(即现实时钟时间)。
ITIMER_VIRTUAL
:定时器基于进程的虚拟时间(即CPU执行用户模式代码所花费的时间)。
ITIMER_PROF
:定时器基于进程时间和系统时间,通常用于分析程序的执行时间。
一般情况下,我们均使用 ITIMER_REAL.
(2)new_value
:指向itimerval
结构体的指针,该结构体定义了定时器的一些必要参数。itimerval
结构体定义如下:
struct itimerval { struct timeval it_interval; // 下次定时器到期的时间间隔 struct timeval it_value; // 定时器首次到期的时间
}; struct timeval { time_t tv_sec; // 秒 suseconds_t tv_usec; // 微秒
};
it_value
为定时器首次到达定时时间的时长。如果此值为0,则定时器立即到期。
it_interval
为当定时器首次到达定时时长之后再次到期的时间间隔。如果此值为0,则定时器只会到期一次。
若此函数执行成功,返回0;若执行失败,返回-1.
2.signal函数
signal
函数用于处理操作系统发送给进程的信号,定义如下:
#include <signal.h>
void (*signal(int sig, void (*func)(int)))(int);
其中:
(1)sig
:指定要处理的信号的编号。比如SIGINT
表示中断信号,SIGTERM
表示终止信号等。
(2)func
:指向信号处理函数的指针。该函数应具有一个整数参数(对应于发送的信号编号),并且没有返回值(即返回类型为void
)。如果此参数为NULL,则该信号将被忽略。
该函数若执行成功,返回指向先前为该信号设置的信号处理函数的指针;如果失败,返回SIG_ERR。
3.举例
先介绍我们代码要实现的功能:运行程序,“Waiting for timer...”不断输出,直到5秒后,它会输出“时间到达了”并退出程序。
#include <stdio.h>
#include <signal.h>
#include <sys/time.h>
#include <iostream>
#include <unistd.h>
void time_test(int sig){std::cout<<"时间到达了"<<std::endl;exit(0);
}
int main(){struct itimerval timer;signal(SIGALRM,time_test);timer.it_interval.tv_sec=0; // 设置为一次性触发timer.it_interval.tv_usec=0;timer.it_value.tv_sec=5; // 设置定时器超时时间为5秒 timer.it_value.tv_usec = 0; setitimer(ITIMER_REAL,&timer,NULL);while(1) { std::cout<<"Waiting for timer... "<<std::endl;sleep(1); // 等待1秒 } return 0;
}
运行得到结果:
可以看出我们成功实现对 setitimer(间隔定时器)和signal(信号处理函数)的应用