POSIX定时器:timer_settime()的使用

POSIX创建、初始化以及删除一个定时器的行动被分为三个不同的函数:timer_create()(创建定时器)、timer_settime()(初始化定时器)以及timer_delete(销毁它)

 

一个典型的例子如:

 

#include <sys/time.h>

timer_t fade_in_timer;

int myclass::starttimer()

{

    struct sigevent evp; 

    memset(&evp, 0, sizeof(evp));

    evp.sigev_value.sival_ptr = this; //这里传一个参数进去,在timer的callback回调函数里面可以获得它  

    evp.sigev_notify = SIGEV_THREAD; //定时器到期后内核创建一个线程执行sigev_notify_function函数 

    evp.sigev_notify_function = fade_in_callback; //这个就是指定回调函数

 

    int ret = 0;

    ret = timer_create(CLOCK_REALTIME, &evp, &fade_in_timer);

    if(ret < 0)

    {

        printf("timer_create() fail, ret:%d", ret);

        return ret;

    }

 

    struct itimerspec ts;

    ts.it_interval.tv_sec = 0;

    ts.it_interval.tv_nsec = 200000000; //200ms 

    ts.it_value.tv_sec = 0;

    ts.it_value.tv_nsec = 200000000; //200ms 

    ret = timer_settime(fade_in_timer, TIMER_ABSTIME, &ts, NULL);

    if(ret < 0)

    {

        printf("timer_settime() fail, ret:%d", ret); 

        timer_delete(fade_in_timer);

        timer_created = false;

        return ret;

    } 

    return 0;

}

 

/*static*/void myclass::fade_in_callback(union sigval v)

    //v.sival_ptr 就是创建timer时传进来的指针,最后在合适的地方删除一下timer

    myclass *ptr = (myclass*)v.sival_ptr;

    timer_delete(audiotrack->fade_in_timer);

}

 

使用timer时注意两点:

1.回调函数如果不是C函数而是类的成员函数,则不能用普通成员函数,必须用静态成员函数,因为普通成员函数含有隐含参数--this指针

2.timer定时的时间间隔,第一次是ts.it_value这么长,后面每次时间间隔是ts.it_interval这么长

    ts.it_interval.tv_sec = 0;

    ts.it_interval.tv_nsec = 200000000; //200ms 

    ts.it_value.tv_sec = 0;

    ts.it_value.tv_nsec = 200000000; //200ms 

 

参考:

http://www.kernel.org/doc/man-pages/online/pages/man2/timer_create.2.html

http://blog.sina.com.cn/s/blog_49b191150100kx0p.html

  • 1
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用 POSIX 定时器的重复定时器功能来实现多次触发。具体方法如下: 1. 创建一个 POSIX 定时器,设置 timer_create() 函数的第三个参数为 TIMER_PERIODIC 表示创建一个重复定时器。 2. 设置定时器的初始值和间隔,可以使用 timer_settime() 函数来实现。 3. 在定时器触发时的回调函数中执行需要重复执行的操作。 4. 如果需要停止定时器,可以使用 timer_delete() 函数来删除定时器。 下面是一个简单的示例代码,每隔 1 秒输出一次 "Hello World",共输出 5 次: ```c #include <stdio.h> #include <signal.h> #include <time.h> timer_t timerid; void timer_handler(int signo) { static int count = 0; printf("Hello World\n"); count++; if (count >= 5) { timer_delete(timerid); } } int main() { struct sigevent sev; struct itimerspec its; sev.sigev_notify = SIGEV_SIGNAL; sev.sigev_signo = SIGUSR1; sev.sigev_value.sival_ptr = &timerid; timer_create(CLOCK_REALTIME, &sev, &timerid); its.it_value.tv_sec = 1; its.it_value.tv_nsec = 0; its.it_interval.tv_sec = 1; its.it_interval.tv_nsec = 0; timer_settime(timerid, 0, &its, NULL); signal(SIGUSR1, timer_handler); while (1) { // 等待信号 } return 0; } ``` 在上面的代码中,timer_create() 函数创建了一个 POSIX 定时器timer_settime() 函数设置了定时器的初始值和间隔,也就是每隔 1 秒触发一次定时器。在信号处理函数中,输出 "Hello World" 并计数,当计数达到 5 时,使用 timer_delete() 函数删除定时器。最后,程序进入一个死循环等待信号的到来。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值