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

Linux函数篇 同时被 2 个专栏收录
47 篇文章 1 订阅
45 篇文章 3 订阅

笔记:

在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(;;)
        ;
}


  • 1
    点赞
  • 0
    评论
  • 1
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

打赏
文章很值,打赏犒劳作者一下
相关推荐
©️2020 CSDN 皮肤主题: 博客之星2020 设计师:CY__ 返回首页

打赏

fulinux

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

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

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

打赏作者

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

抵扣说明:

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

余额充值