1. 程式人生 > >linux下定時器的使用--timer_create等函數集

linux下定時器的使用--timer_create等函數集

rest eat 處理 stdio.h lag fin handle 之前 reat

程序1:采用新線程派駐的通知方式

程序2:通知方式為信號的處理方式

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

#define CLOCKID CLOCK_REALTIME

void sig_handler(int signo)
{
printf("timer_signal function! %d\n", signo);
}

int main()
{
//XXX int sigaction(int signum, const struct sigaction *act, struct sigaction *oldact);
// signum--指定的信號編號,可以指定SIGKILL和SIGSTOP以外的所有信號編號
// act結構體--設置信號編號為signum的處理方式
// oldact結構體--保存上次的處理方式
//
// struct sigaction
// {
// void (*sa_handler)(int); //信號響應函數地址
// void (*sa_sigaction)(int, siginfo_t *, void *); //但sa_flags為SA——SIGINFO時才使用
// sigset_t sa_mask; //說明一個信號集在調用捕捉函數之前,會加入進程的屏蔽中,當捕捉函數返回時,還原
// int sa_flags;
// void (*sa_restorer)(void); //未用
// };
//
timer_t timerid;
struct sigevent evp;

struct sigaction act;
memset(&act, 0, sizeof(act));
act.sa_handler = sig_handler;
act.sa_flags = 0;

// XXX int sigaddset(sigset_t *set, int signum); //將signum指定的信號加入set信號集
// XXX int sigemptyset(sigset_t *set); //初始化信號集

sigemptyset(&act.sa_mask);

if (sigaction(SIGUSR1, &act, NULL) == -1)
{
perror("fail to sigaction");
exit(-1);
}

memset(&evp, 0, sizeof(struct sigevent));
evp.sigev_signo = SIGUSR1;
evp.sigev_notify = SIGEV_SIGNAL;
if (timer_create(CLOCK_REALTIME, &evp, &timerid) == -1)
{
perror("fail to timer_create");
exit(-1);
}

struct itimerspec it;
it.it_interval.tv_sec = 2;
it.it_interval.tv_nsec = 0;
it.it_value.tv_sec = 1;
it.it_value.tv_nsec = 0;
if (timer_settime(timerid, 0, &it, 0) == -1)
{
perror("fail to timer_settime");
exit(-1);
}

pause();

return 0;
}

linux下定時器的使用--timer_create等函數集