Linux定時器的实现.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Linux定時器的实现

Linux定时器的实现 #include stdio.h #include time.h #include sys/time.h #include stdlib.h #include signal.h int count = 0; void set_timer() { struct itimerval itv, oldtv; itv.it_interval.tv_sec = 0; itv.it_interval.tv_usec = 1000; itv.it_value.tv_sec = 0; itv.it_value.tv_usec = 1000; setitimer(ITIMER_REAL, itv, oldtv); } void sigalrm_handler(int sig) { count++; } int main( ) { signal(SIGALRM, sigalrm_handler); set_timer(); while(count 10000){ } printf(count = %d\n, count); exit(0); } setitimer函数的精度决定于系统时钟的分辨率,在我的系统中要40s才能返回,说明分辨率不到1ms。如果改成间隔10ms(10000us)的话,系统100s返回,很准确。一般操作系统的分辨率都为10ms。注意,信号会中断低速系统调用,所以这里用循环延迟,而不是用sleep之类的函数。 还有一种方法是基于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 int main(void) { int i, fd, retval, irqcount = 0; unsigned long tmp, data; fd = open (/dev/rtc, O_RDONLY); if (fd == -1) { perror(/dev/rtc); exit(errno); } fprintf(stderr, \n\tRTC Driver Test Example.\n); /* Turn on update interrupts (one per second) */ retval = ioctl(fd, RTC_UIE_ON, 0); if (retval == -1) { perror(ioctl); exit(errno); } fprintf(stderr, Counting 5 update (1/sec) interrupts from reading /dev/rtc:); fflush(stderr); for (i=1; i6; i++) { /* This read will block */ retval = read(fd, data, sizeof(unsigned long)); if (retval == -1) { perror(read); exit(errno); } fprintf(stderr, %d,i); fflush(stderr); irqcount++; } /* Turn off update interrupts */ retval = ioctl(fd, RTC_UIE_OFF, 0); if (retval == -1) { perror(ioctl); exit(errno); } /* Read periodic IRQ rate */ retval = ioctl(fd, RTC_IRQP_READ, tmp);

文档评论(0)

sd47f8cI + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档