【转】Linux Posix Timer使用
原文网址:http://blog.csdn.net/hongszh/article/details/8608781
最强大的定时器接口来自POSIX时钟系列,其创建、初始化以及删除一个定时器的行动被分为三个不同的函数:timer_create()(创建定时器)、timer_settime()(初始化定时器)以及timer_delete(销毁它)。
man timer_create/timer_settime,可以看到man帮助的详细文档:
- TIMER_CREATE(2) Linux Programmer's Manual
- NAME
- timer_create - create a POSIX per-process timer
- SYNOPSIS
- #include <signal.h>
- #include <time.h>
- int timer_create(clockid_t clockid, struct sigevent *sevp,
- timer_t *timerid);
- int timer_settime(timer_t timerid, int flags,
- const struct itimerspec *new_value,
- struct itimerspec * old_value);
- int timer_gettime(timer_t timerid, struct itimerspec *curr_value);
我的实现如下:
1. 定义timer timeout的函数指针类型:
- typedef void (*timerTimeout)(union sigval sig);
2. 为我们的GstPlayer定义两个timer ID:
- timer_t mSeekTimer;
- timer_t mPrepareAsyncTimer;
3. 定义createTimer函数,创建timer,设置timeout函数
timerId: 输入输出参数
func: timer timeout函数
- void createTimer(timer_t *timerId, timerTimeout func)
- {
- struct sigevent sev;
- sev.sigev_notify = SIGEV_THREAD;
- sev.sigev_signo = SIGRTMIN;
- sev.sigev_value.sival_ptr = gPlayer;
- sev.sigev_notify_function = func;
- sev.sigev_notify_attributes = NULL;
- /* create timer */
- if (timer_create (CLOCK_REALTIME, &sev, timerId) == -1)
- {
- ERR ("timer_create, error");
- return;
- }
- if (*timerId == -1)
- ERR ("timer_create error, id is -1");
- return;
- }
4. setTimer函数, 调用linux的timer_settime, 如果还没到time out,重置之前的timer
如果已经time out,那就得重新调用createTimer生成有效的timer ID,然后才能调用setTimer开始定时器计时。
-这里,将interval参数设置为0,指定我的定时器不工作在循环模式。
-timeMSec是输入参数,指定time out的时间,单位为毫秒。
- void setTimer(timer_t *timerId, int timeMSec)
- {
- struct itimerspec its;
- /* Start the timer */
- its.it_value.tv_sec = timeMSec / 1000;
- its.it_value.tv_nsec = (timeMSec % 1000) * 1000000;
- its.it_interval.tv_sec = 0;
- its.it_interval.tv_nsec = 0;
- if (timer_settime (*timerId, 0, &its, NULL) == -1)
- {
- ERR ("timer_settime error");
- }
- DEBUG ("call timer_settime reset timer done.");
- return;
- }
seekTimerTimeout函数,time out以后,销毁之前调用createTimer创建的timer,完成time out后要做的工作
- void seekTimerTimeout(union sigval sig)
- {
- GstPlayer *player = (GstPlayerplayer*)sig.sival_ptr;
- if (player->mSeekTimer != -1)
- {
- DEBUG("timeout, delete timer:Id = %d",
- player->mSeekTimer);
- timer_delete(player->mSeekTimer);
- player->mSeekTimer = -1;
- }
- // ... 完成time out后要做的工作
- }
prepareAsyncTimeout的time out函数:
- void prepareAsyncTimeout(union sigval sig)
- {
- GstStateChangeReturn state_return;
- GstPlayer *player = (GstPlayerplayer*)sig.sival_ptr;
- if (player->mPrepareAsyncTimer != -1)
- {
- DEBUG("timeout, delete timer:Id = %d",
- player->mPrepareAsyncTimer);
- timer_delete(player->mPrepareAsyncTimer);
- player->mPrepareAsyncTimer = -1;
- }
- // ...完成time out后要做的工作
- }
调用一:
- 创建timer,设定prepareAsyncTimeout
- 开始timer,timeout时间为500ms
- createTimer(&mPrepareAsyncTimer, prepareAsyncTimeout);
- setTimer(&mPrepareAsyncTimer, 500/*ms*/);
调用二:
- 创建timer,设定timeout回调函数。
- // create timer
- if (mSeekTimer == -1)
- {
- createTimer(&mSeekTimer, seekTimerTimeout);
- }
- 判断mSeekTimer是否有效,有效,计算到timeout的剩余时间,如果还没到timeout,重置timer,
- 开始新的计时。
- // if timer exist and not expire, reset timer.
- if (mSeekTimer != -1)
- {
- gulong remaining = 0; //us
- struct itimerspec its;
- timer_gettime(mSeekTimer, &its);
- remaining = its.it_value.tv_sec * 1000000
- its.it_value.tv_nsec / 1000;
- DEBUG ("-- remaining time = %lu us", remaining);
- if ((100/*ms*/ * 1000 - remaining) > 0)
- {
- setTimer(&mSeekTimer, 100/*ms*/);
- DEBUG ("the new seek interval < 100ms, return");
- mSeekCount = 1;
- return TRUE;
- }
- }
参考:
http://blog.163.com/zheng_he_xiang/blog/static/18650532620116311020390/
http://blog.csdn.net/leo9150285/article/details/8271910
【转】Linux Posix Timer使用的更多相关文章
- Linux时间子系统之(六):POSIX timer
专题文档汇总目录 Notes:首先讲解了POSIX timer的标识(唯一识别).POSIX Timer的组织(管理POSIX Timer).内核中如何抽象POSIX Timer:然后分析了POSIX ...
- Linux时间子系统(六) POSIX timer
一.前言 在用户空间接口函数文档中,我们描述了和POSIX timer相关的操作,主要包括创建一个timer.设定timer.获取timer的状态.获取timer overrun的信息.删除timer ...
- Linux posix线程库总结
由于历史原因,2.5.x以前的linux对pthreads没有提供内核级的支持,所以在linux上的pthreads实现只能采用n:1的方式,也称为库实现. 线程的实现,经历了如下发展阶段: Linu ...
- POSIX Timer
SYNOPSIS #include <signal.h> /* only timer_create need this header */ #include <time.h> ...
- linux POSIX 信号量介绍
信号量一.什么是信号量信号量的使用主要是用来保护共享资源,使得资源在一个时刻只有一个进程(线程)使用.多线程可以同时运行多个线程函数完成功能,但是对于共享数据如果不加以锁定,随意改变共享数据的值会发生 ...
- linux Posix 信号量 一
信号量是一种用于提供不同进程间或一个给定进程的不同线程间同步手段的原语. linux提供两种信号量,“内核信号量”和“用户态进程信号量”,“用户态信号量”又分为“Posix”,“System V”信号 ...
- linux Posix线程同步(条件变量) 实例
条件变量:与互斥量一起使用,暂时申请不到某资源时进入条件阻塞等待,当资源具备时线程恢复运行 应用场合:生产线程不断的生产资源,并通知产生资源的条件,消费线程在没有资源情况下进入条件等待,一直等到条件信 ...
- linux Posix 信号量 二
一.Posix信号量 1.Posix信号量分为两种: 1. 有名信号量:使用Posix IPC名字标识(有名信号量总是既可用于线程间的同步,又可以用于进程间的同步) 2. 内存信号量:存放在共 ...
- linux POSIX信号量
POSIX信号量机制是3种IPC机制之一,3种IPC机制源于POSIX.1的实时扩展. 创建一个新的命名信号量或者使用一个现有信号量 #include <fcntl.h> #include ...
随机推荐
- zend studio 10 字体,颜色,快捷键等相关设置
一.修改字体 没想到zend studio 10中对中文显示不太好看,似乎有点小了.修改如下:打开 Window->Preferences->General->Appearance- ...
- oracle 字符集
---- 在国内外大中型数据库管理系统中,把ORACLE作为数据库管理平台的用户比较多.ORACLE 不论是数据库管理能力还是安全性都是无可非议的,但是,它在汉字信息的显示方面着实给中国用户带来不少麻 ...
- HDU4670 Cube number on a tree 树分治
人生的第一道树分治,要是早点学我南京赛就不用那么挫了,树分治的思路其实很简单,就是对子树找到一个重心(Centroid),实现重心分解,然后递归的解决分开后的树的子问题,关键是合并,当要合并跨过重心的 ...
- SQL server 复习一
第一天 下面我们从最基础的开始: 在运行里面输入:services.msc 一.启动服务 二.数据库登录的两种身份验证方式 另外一种身份验证方式就是SQL Server身份验证. sa不能使用的时候可 ...
- 是什么让 Ubuntu 选用 Qt 而不是 GTK?
是什么让 Ubuntu 选用 Qt 而不是 GTK? 一个正在发生的事实,Ubuntu正在不断Qt化!我曾一直在抱怨的Software Center,今日一看源码,竟然有softwarecenter/ ...
- jQuery好用插件
jQuery图片轮播插件(smallslider):http://fz.sjtu.edu.cn/zsw/js/smallslider/ jQuery消息通知(noty):http://www.360d ...
- create user 'root'@'localhost' identified by 。。。
- muParser公式库使用简介( 转)
muParser是一个跨平台的公式解析库,它可以自定义多参数函数,自定义常量.变量及一元前缀.后缀操作符,二元操作符等,它将公式编译成字节码,所以计算起来非常快. 当前版本V1.28,官方网址http ...
- (2)WinForm中改变Tab选项卡的顺序
Tab选项卡选中,在其属性中找到TabPages这个属性.点进去,可以通过上下移动标签卡改变标签卡的顺序.
- Python中的split()函数的使用方法
函数:split() Python中有split()和os.path.split()两个函数,具体作用如下:split():拆分字符串.通过指定分隔符对字符串进行切片,并返回分割后的字符串列表(lis ...