下面是我的timer_create的例子,编译的时候要加上rt库,这是linux的realtime库:
gcc -o test test.c
#include <stdio.h> #define rdtsc(low,high) __asm__ __volatile__("rdtsc" : "=a" (low), "=d" (high)) timer_t tt; void handler (int sig, siginfo_t * extra, void *cruft) int main () sigfillset (&sigset); struct sigaction sa; if (sigaction (SIGRTMIN, &sa, NULL) < 0) struct sigevent timer_event; timer.it_interval.tv_sec = 0; timer_event.sigev_notify = SIGEV_SIGNAL; if (timer_create (CLOCK_REALTIME, &timer_event, &tt) < 0) if (timer_settime (tt, 0, &timer, NULL) < 0) while (i++ < 10) 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