Linux下实现定时器Timer的几种方法
来源:互联网 发布:知乎黑暗之魂3 编辑:程序博客网 时间:2024/05/21 09:45
定时器Timer应用场景非常广泛,在Linux下,有以下几种方法:
1,使用sleep()和usleep()
其中sleep精度是1秒,usleep精度是1微妙,具体代码就不写了。使用这种方法缺点比较明显,在Linux系统中,sleep类函数不能保证精度,尤其在系统负载比较大时,sleep一般都会有超时现象。
2,使用信号量SIGALRM + alarm()
这种方式的精度能达到1秒,其中利用了*nix系统的信号量机制,首先注册信号量SIGALRM处理函数,调用alarm(),设置定时长度,代码如下:
#include <stdio.h>#include <signal.h>void timer(int sig){ if(SIGALRM == sig) { printf("timer\n"); alarm(1); //we contimue set the timer } return ;}int main(){ signal(SIGALRM, timer); //relate the signal and function alarm(1); //trigger the timer getchar(); return 0;}alarm方式虽然很好,但是无法首先低于1秒的精度。
3,使用RTC机制
RTC机制利用系统硬件提供的Real Time Clock机制,通过读取RTC硬件/dev/rtc,通过ioctl()设置RTC频率,代码如下:
#include <stdio.h>#include <linux/rtc.h>#include <sys/ioctl.h>#include <sys/time.h>#include <sys/types.h>#include <fcntl.h>#include <unistd.h>#include <errno.h>#include <stdlib.h>int main(int argc, char* argv[]){ unsigned long i = 0; unsigned long data = 0; int retval = 0; int fd = open ("/dev/rtc", O_RDONLY); if(fd < 0) { perror("open"); exit(errno); } /*Set the freq as 4Hz*/ if(ioctl(fd, RTC_IRQP_SET, 1) < 0) { perror("ioctl(RTC_IRQP_SET)"); close(fd); exit(errno); } /* Enable periodic interrupts */ if(ioctl(fd, RTC_PIE_ON, 0) < 0) { perror("ioctl(RTC_PIE_ON)"); close(fd); exit(errno); } for(i = 0; i < 100; i++) { if(read(fd, &data, sizeof(unsigned long)) < 0) { perror("read"); close(fd); exit(errno); } printf("timer\n"); } /* Disable periodic interrupts */ ioctl(fd, RTC_PIE_OFF, 0); close(fd); return 0;}这种方式比较方便,利用了系统硬件提供的RTC,精度可调,而且非常高。
4,使用select()
这种方法在看APUE神书时候看到的,方法比较冷门,通过使用select(),来设置定时器;原理利用select()方法的第5个参数,第一个参数设置为0,三个文件描述符集都设置为NULL,第5个参数为时间结构体,代码如下:
#include <sys/time.h>#include <sys/select.h>#include <time.h>#include <stdio.h>/*seconds: the seconds; mseconds: the micro seconds*/void setTimer(int seconds, int mseconds){ struct timeval temp; temp.tv_sec = seconds; temp.tv_usec = mseconds; select(0, NULL, NULL, NULL, &temp); printf("timer\n"); return ;}int main(){ int i; for(i = 0 ; i < 100; i++) setTimer(1, 0); return 0;}这种方法精度能够达到微妙级别,网上有很多基于select()的多线程定时器,说明select()稳定性还是非常好。
总结:如果对系统要求比较低,可以考虑使用简单的sleep(),毕竟一行代码就能解决;如果系统对精度要求比较高,则可以考虑RTC机制和select()机制。
- Linux下实现定时器Timer的几种方法
- Linux下实现定时器Timer的几种方法
- Linux下实现定时器Timer的几种方法
- linux的几种定时器实现-(timer implementation under linux)
- linux 下定时器timer的使用
- Android实现定时器的几种方法
- Linux 定时器的几种方法
- 定时器(Timer)的实现
- 定时器Timer的实现
- java 定时器Timer的三种实现
- Timer---Android 定时器的三种实现
- (笔记)linux下用select函数的超时实现timer(时间定时器s)
- 使用Java 自身Timer API实现定时器的方法
- 定时器的几种方法
- linux内核定时器--------一个简单的timer的实现
- linux定时器Timer的用法
- linux定时器Timer的用法
- linux下的几种时钟和定时器机制
- 解决ubuntu程序目录中存在空格 启动器无法正常开启程序
- 黑马程序员--动态代理
- [IPhone] 仅在Debug编译的NSLog
- “圆”值得并不是对圆的表面认识,而是圆所蕴含的思想
- linux笔记 二
- Linux下实现定时器Timer的几种方法
- 网站开发常见问题大全
- iphone开发 UITableView数据刷新
- typedef和define具体的详细区别
- Debug一些有用的信息Tips
- 软件测试类工具大全
- Linux常用命令大全 (非常有用)
- iPhone私有API使用
- 查找不到创建的索引