假设pthread_cond_timewait调用挂起之后在等待时间到期的时候,mutex还被其他线程锁占用的情况下会发生什么?
假设先来现在有两个线程:
线程1在lock之后进入timewait状态超时时间60s,线程2在线程1进入time_wait释放mutex之后获得mutex,并且sleep 120s,也进入睡眠,
线程1启动后线程2随后启动,日志如下:
可以看到60s后线程1的timewait虽然超时没有任何动作,根据文档所说pthread_cond_timewait超时之后会重新获取mutex,显然从第四句日志可以看到120s后线程2释放mutex退出了线程,此时线程1的timewait才返回,同时返回超时结果,也就是说中间为了等待线程2释放mutex而多阻塞了60s,所以可以看到pthread_cond_timewait即便是在时间超时的情况下一定会等到真正获得mutex之后才会返回。