linux应用程序中的延时和定时器

本文介绍Linux环境下如何使用定时器配合kill函数实现周期性的信号处理。通过具体代码示例展示了如何设置不同类型的定时器,并在接收到信号时执行相应的处理函数。探讨了基于进程休眠之外的延时方法。

笔记:

在linux应用程序中延时有sleep()、msleep()和usleep()函数之类的延时,也有如下形式的延时:

    struct timeval delay;
    delay.tv_sec = sleepSecond;
    delay.tv_usec = 0;
    select( 0, NULL, NULL, NULL, &delay );

但是基本上都是基于进程休眠的,好像没有循环等待的延时,有待证实,目前没发现。


考虑到一个问题,如果定时发送信号,执行相应一个信号处理函数时,该函数还么有执行完成,另一个信号又来了,怎么处理呢?答案是等待前面一个信号处理完成。

定时器配合kill函数一起使用,可以满足某些想立即执行又要有周期执行相应函数的特殊要求,如下:

/*********************************************************************************
 *      Copyright:  (C) 2014 EAST
 *                  All rights reserved.
 *
 *       Filename:  setitimer.c
 *    Description:  This file 
 *                 
 *        Version:  1.0.0(08/08/2014)
 *         Author:  fulinux <fulinux@sina.com>
 *      ChangeLog:  1, Release initial version on "08/08/2014 12:58:48 PM"
 *                 
 ********************************************************************************/
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <signal.h>
#include <time.h>
#include <sys/time.h>

static int switch_val = 0;

void sigroutine(int signo){
    switch (signo){
        case SIGALRM:
            printf("Catch a signal -- SIGALRM \n");
            break;
        case SIGVTALRM:
            printf("Catch a signal -- SIGVTALRM \n");
            switch(switch_val){
                case 0:
                    printf ("switch_val =  0\n");
                    break;
                case 1:
                    printf ("switch_val =  1\n");
                    break;
                case 2:
                    printf ("switch_val =  2\n");
                    break;
                case 3:
                    printf ("switch_val =  3\n");
                    break;
                default:
                    return;
            }
            break;
    }
    return;
}
int main()
{
    struct itimerval value, ovalue, value2;          //(1)

    printf("process id is %d\n", getpid());

    signal(SIGALRM, sigroutine);
    signal(SIGVTALRM, sigroutine);

    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, &ovalue);     //(2)
    value2.it_value.tv_sec = 0;
    value2.it_value.tv_usec = 1;
    value2.it_interval.tv_sec = 0;
    value2.it_interval.tv_usec = 500000;
    setitimer(ITIMER_VIRTUAL, &value2, &ovalue);

#if 0
    struct timeval delay;
    delay.tv_sec = 0;
    delay.tv_usec = 500000;
    select(0, NULL, NULL, NULL, &delay);
#endif
    switch_val = 1;
    kill(getpid(), SIGVTALRM);
    printf ("fulinux 1\n");

    switch_val = 2;
    kill(getpid(), SIGVTALRM);
    printf ("fulinux 2\n");

    switch_val = 3;
    kill(getpid(), SIGVTALRM);
    printf ("fulinux 3\n");

    for(;;)
        ;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

fulinux

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值