alarm的参数为秒数,在经过指定秒数后,alarm会发出一个SIGALRM信号
singal函数用来绑定信号处理器函数,这里绑定的是timer,被绑定的函数必须固定为返回值void、参数int。
只需要alarm(时间)就设置了,可能由于getchar需要进入中断导致信号被挂起所以没反应吧,可以试试把getchar换成别的东西来延时看看
给你两个函数参考omsTimer函数是处理定时事件,void(*handle)(union sigval v)参数就是处理事件的函数指针。
int omsSetTimer(timer_t *tId,int value,int interval)就是设置定时器。
按你说的,如果要同时起多个定时器,需要定义一个数组timer_t tm[n]int it[n]tm就是定时器结构,it用来记录对应的定时器是否已经使用,使用中的就是1,没用的就是0;
主进程消息来了就从it找一个没用的来omsSetTimer,如果收到终止消息,那omsSetTimer 定时时间为0
int omsTimer(timer_t *tId,int iValue,int iSeconds ,void(*handle)(union sigval v),void * param)
{
struct sigevent se
struct itimerspec ts
memset (&se, 0, sizeof (se))
se.sigev_notify = SIGEV_THREAD
se.sigev_notify_function = handle
se.sigev_value.sival_ptr = param
if (timer_create (CLOCK_REALTIME, &se, tId) <0)
{
return -1
}
ts.it_value.tv_sec = iValue
// ts.it_value.tv_sec =3
//ts.it_value.tv_nsec = (long)(iValue % 1000) * (1000000L)
ts.it_value.tv_nsec = 0
ts.it_interval.tv_sec = iSeconds
//ts.it_interval.tv_nsec = (long)(iSeconds % 1000) * (1000000L)
ts.it_interval.tv_nsec = 0
if (timer_settime(*tId, TIMER_ABSTIME, &ts, NULL) <0)
{
return -1
}
return 0
}
int omsSetTimer(timer_t *tId,int value,int interval)
{
struct itimerspec ts
ts.it_value.tv_sec =value
//ts.it_value.tv_nsec = (long)(value % 1000) * (1000000L)
ts.it_value.tv_nsec = 0
ts.it_interval.tv_sec = interval
//ts.it_interval.tv_nsec = (long)(interval % 1000) * (1000000L)
ts.it_interval.tv_nsec = 0
if (timer_settime(*tId, TIMER_ABSTIME, &ts, NULL) <0)
{
return -1
}
return 0
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)