linux多进程基础(6):setitimer(间隔定时器)和signal(信号处理函数)

发布时间:2024年01月17日

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(信号处理函数)的应用

文章来源:https://blog.csdn.net/shnhe/article/details/135562524
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。