日期:2014-05-16  浏览次数:20821 次

【求助】请教一下关于条件变量的一个问题。
请问一下pthread_cond_timedwait 在什么情况下,超时时间到了没返回?现在遇到了一个比较奇怪的问题。我设置的是超时时间是当前时间+5秒 但是一直阻塞在timedwait,时间超过了也没返回。之前有pthread_mutex_lock的。



------解决方案--------------------
在CU问即可,这两边我都在混。
------解决方案--------------------
无代码,无真相!

简单例子
C/C++ code

#include <stdio.h>
#include <time.h>

#include <pthread.h>

pthread_mutex_t mutex =  PTHREAD_MUTEX_INITIALIZER;
pthread_cond_t cond = PTHREAD_COND_INITIALIZER;

int main(int argc, char *argv[])
{
        struct timespec ts;

        ts.tv_sec = 5 + time(NULL);
        ts.tv_nsec = 0;
        pthread_mutex_lock(&mutex);
        system("date '+%H:%M:%S'");
        pthread_cond_timedwait(&cond, &mutex, &ts);
        system("date '+%H:%M:%S'");
        pthread_mutex_unlock(&mutex);

        clock_gettime(CLOCK_REALTIME, &ts);
        ts.tv_sec += 5;
        pthread_mutex_lock(&mutex);
        system("date '+%H:%M:%S'");
        pthread_cond_timedwait(&cond, &mutex, &ts);
        system("date '+%H:%M:%S'");
        pthread_mutex_unlock(&mutex);

        return 0;
}