你是指延迟函数还是定时调用,比如到11:12:13秒执行某个函数?
如果是延时函数用
usleep(usec) // 微妙sleep(sec) // 秒
如果是定时执行的话,你只能开个线程或while,每隔1s判断下当前系统时间,
struct tm *ptmlong ts
int y,m,d,h,n,s
ts = time(NULL)
ptm = localtime(&ts)
y = ptm-> tm_year+1900 //年
m = ptm-> tm_mon+1 //月
d = ptm-> tm_mday //日
h = ptm-> tm_hour //时
n = ptm-> tm_min //分
s = ptm-> tm_sec //秒
照着上面的格式组成字符串进行判断,到点了就执行就可以了
crontab-e
,然后,输入
*
*/1
*
*
*
这个是每隔一个小时,执行一次。。。
楼主需要的情况,at,crontab
都是无法完全满足的,因为,crontab
每次执行,只能是每隔一段时间(但是间隔时间都是相同的),或者在某个时刻,楼主这种,情况很特殊,估计,需要,编写c
程序,才可以搞定的。。。
给你两个函数参考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条)