您可以改为使用条件变量,并选择单调时钟作为参考时钟.信号量有点老,我会避免在新的应用程序中使用它们.如果您愿意,可以使用条件变量和互斥量轻松实现信号量.
pthread_condattr_t cattr;
pthread_condattr_init(&cattr);
pthread_condattr_setclock(&cattr, CLOCK_MONOTONIC);
pthread_cond_t cond;
pthread_cond_init(&cond, &cattr);
struct timespec ts;
clock_gettime(CLOCK_MONOTONIC, &ts);
ts.tv_nsec += 100000000;
if (ts.tv_nsec >= 1000000000) {
ts.tv_nsec -= 1000000000;
ts.tv_sec += 1;
}
int r = pthread_cond_timedwait(&cond, &mutex, &ts);
if (r == ETIMEDOUT) {
// ...
} else {
// ...
}
单调时钟“不受系统时间内不连续跳跃的影响”(man clock_gettime),因此它正是您对此类应用所需要的.
你说,
Now it happens that the system time gets set by an external process (ntp) while waiting for the semaphore.
但情况比这更糟糕……系统时钟可能会在你调用clock_gettime()之后调用sem_timedwait()之前进行调整……所以就你所知,你希望sem_timedwait()等待两天.