Linux下实时定时器在C语言中的实现和应用

linux下还有一种高精度的定时器,那就是posix_timer.我记得以前看代码的时候CLOCK_REALTIME的定时器似乎用的就是rdtsc指令,不过现在不确定了,先放到一边。原理上来说,可以在变频的时候也使用rdtsc指令,因为CPU的频率我们也是知道的,变频的时候内核也是知道的。

下面是我的timer_create的例子,编译的时候要加上rt库,这是linux的realtime库:

gcc -o test test.c

#include <stdio.h>
#include <unistd.h>
#include <signal.h>
#include <stdlib.h>
#include <time.h>

#define rdtsc(low,high) __asm__ __volatile__("rdtsc" : "=a" (low), "=d" (high))

timer_t tt;

void handler (int sig, siginfo_t * extra, void *cruft)
{
  static last_i=0;
  unsigned int i, j;
  rdtsc(i,j);
  printf ("time:%u, %u, [%u] %uHZ ", j, i, i-last_i, (i-last_i)*10/1000000);
  last_i = i;
}

int main ()
{
  int i=0;
  sigset_t sigset;

  sigfillset (&sigset);
  sigdelset (&sigset, SIGRTMIN);
  sigprocmask (SIG_SETMASK, &sigset, NULL);

  struct sigaction sa;
  sigfillset (&sa.sa_mask);
  sa.sa_flags = SA_SIGINFO;
  sa.sa_sigaction = handler;

  if (sigaction (SIGRTMIN, &sa, NULL) < 0)
  {
    perror ("sigaction failed ");
    exit (-1);
  }

  struct sigevent timer_event;
  struct itimerspec timer;

  timer.it_interval.tv_sec = 0;
  timer.it_interval.tv_nsec = 100 * 1000 * 1000;
  timer.it_value = timer.it_interval;

  timer_event.sigev_notify = SIGEV_SIGNAL;
  timer_event.sigev_signo = SIGRTMIN;
  timer_event.sigev_value.sival_ptr = (void *) &tt;

  if (timer_create (CLOCK_REALTIME, &timer_event, &tt) < 0)
  {
    perror ("timer_create failed");
    exit (-1);
  }

  if (timer_settime (tt, 0, &timer, NULL) < 0)
  {
    perror ("timer_settime failed");
    exit (-1);
  }

  while (i++ < 10)
  {
    pause ();
  }

  return 0;
}

输出结果:

time:166081, 1934350847, [1934350847] 2163HZ

time:166081, 2120528291, [186177444] 1861HZ

time:166081, 2306679576, [186151285] 1861HZ

time:166081, 2494695630, [188016054] 1880HZ

time:166081, 2680865389, [186169759] 1861HZ

time:166081, 2867018473, [186153084] 1861HZ

time:166081, 3053152230, [186133757] 1861HZ

time:166081, 3239309935, [186157705] 1861HZ

time:166081, 3425467261, [186157326] 1861HZ

time:166081, 3611639266, [186172005] 1861HZ

时间: 2024-09-17 04:03:33

Linux下实时定时器在C语言中的实现和应用的相关文章

linux下编程 ,关于信号sigaction中的sa_flags ,一些改变却不起作用

问题描述 linux下编程 ,关于信号sigaction中的sa_flags ,一些改变却不起作用 linux下编程 ,关于信号sigaction中的sa_flags ,一些改变却不起作用 本人最近在学习linux下的C语言编程,参考书上写程序却遇到了些问题.在程序中 struct sigaction act;act.sa_handler = show_handler;act.sa_flags = SA_RESETHAND | SA_NODEFER ;sigaction(SIGINT&actNU

Linux下多线程编程(C语言)

Linux下多线程编程(C语言) 2.6内核开始使用NPTL(Native POSIX Thread Library)线程库,这个线程库有以下几个目标: POSIX兼容,都处理结果和应用,底启动开销,低链接开销,与Linux Thread应用的二进制兼容,软硬件的可扩展能力,与C++集成等. 这里的线程是指用户空间的线程操作 一.线程相关操作 1.1  pthread_t      pthread_t 在头文件  /usr/include/i386-linux-gnu/bits/pthreadt

Linux下多进程编程(C语言)

Linux下多进程编程(C语言) 一.    进程简介 1.进程是程序的执行.程序是静态的,进程是动态的. 2.进程在内存中有三部分组成:数据段.堆栈段和代码段.          代码段:就是存放程序代码的数据,如果有数个进程运行同一个一个程序,那么它们就可以使用同一个代码段(代码段是可以共享的):          堆栈段:存放的是子程序的返回地址.参数以及程序的局部变量,主要是保存进程的执行的环境,这里用到了栈先进后出的特性,可以看做具有记忆上一次执行的环境.          数据段:存

Linux下实现定时器Timer的几种方法总结_Linux

定时器Timer应用场景非常广泛,在Linux下,有以下几种方法: 1,使用sleep()和usleep() 其中sleep精度是1秒,usleep精度是1微妙,具体代码就不写了.使用这种方法缺点比较明显,在Linux系统中,sleep类函数不能保证精度,尤其在系统负载比较大时,sleep一般都会有超时现象. 2,使用信号量SIGALRM + alarm() 这种方式的精度能达到1秒,其中利用了*nix系统的信号量机制,首先注册信号量SIGALRM处理函数,调用alarm(),设置定时长度,代码

linux下实时查看tomcat运行日志的方法_Linux

1.先切换到:cd usr/local/tomcat5/logs 2.tail -f catalina.out 3.这样运行时就可以实时查看运行日志了 Ctrl+c 是退出tail命令. 顺便讲一下Linux中tail命令 tail 命令从指定点开始将文件写到标准输出.使用tail命令的-f选项可以方便的查阅正在改变的日志文件,tail -f filename会把filename里最尾部的内容显示在屏幕上,并且不但刷新,使你看到最新的文件内容. 1.命令格式; tail[必要参数][选择参数][

linux下的定时器

简介 这篇文章主要记录我在试图解决如何尽可能精确地在某个特定的时间间隔执行某项具体任务时的思路历程,并在后期对相关的API进行的归纳和总结,以备参考. 问题引出 很多时候,我们会有类似"每隔多长时间执行某项任务"的需求,乍看这个问题并不难解决,实则并不容易,有很多隐含条件需要考虑,诸如:时间精度是多少?时间是否允许出现偏差,允许的偏差是多少,偏差之后如何处理?系统的负载如何?这个程序允许占用的系统资源是否有限制?这个程序运行的硬件平台如何? 为了便于分析,我们锁定题目为"每隔

linux下 java JNI调用C语言动态链接库

今天花了至少3个小时跑这个java调c的动态链接库的Hello,native world的程序.把所有犯的错误和要点总结一下!1 java 中 c语言函数的声明    public native static void greeting(); //就像是接口声明一样,不过有native!2 编译 javac HelloNative.java ,然后使用 javahjavah HelloNative会自动产生c的头文件HelloNative.h3 生成的头文件 的 第一句子为  #include

c实现linux下的数据库备份_C 语言

Linux下c实现的数据库备份,只要修改数据库列表文件的信息即可. db_list.txt把后缀去掉即可,一个数据库一行. 1. main.c   #include<sys/types.h> #include<sys/wait.h> #include<ctype.h> #include<unistd.h> #include<string.h> #include<stdlib.h> #include<stdio.h> //待

如何在Linux下实现Java调用C语言编写的程序

问题描述 我在Linux下有一个已经用C语言写好,并编译生成的可执行的加密程序.现在我想在java程序中调用这个C程序.我现在是这样做的:用一个shell脚本运行这个加密程序,Java程序则负责调用shell脚本.Processrt=Runtime.getRuntime().exec("sh/opt/crypt");shell脚本在终端里可以运行,但是写在java程序里就不能运行了.请问,该怎么实现呢? 解决方案 解决方案二:不要格成3道程序,不麻烦吗?你把c程序编译成.so.然后用J