pthread_cond_timedwait不返回导致死锁

remember63 2012-03-08 10:31:52
 while (infoX_Event.flag == 0)
{
dwWaitResult = (__UINT32)pthread_cond_timedwait(&infoX_Event.cv, &infoX_Event.mp, &abst);
if (dwWaitResult == 0) //系统调用返回,需要重新检测flag值
{
// 防止被信号打断,造成错误返回
if (infoX_Event.flag == 0)
{
continue;
}
if (!infoX_Event.bManualReset) //自动RESET
{
infoX_Event.flag = 0;
}
pthread_mutex_unlock(&infoX_Event.mp);
return WAIT_OBJECT_0;
}
else if (dwWaitResult == ETIMEDOUT)
{
pthread_mutex_unlock(&infoX_Event.mp);
return WAIT_TIMEOUT;
}
}


abst是绝对时间(等价于相对时间一秒后,这个是正确的),查看堆栈可知道程序一直在pthread_cond_timedwait阻塞没返回,
(超过30秒)导致系统检测认为死锁。
这个有可能是什么原因造成的啊,不是超时了一定会返回吗?
...全文
335 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
liupengying 2012-05-19
  • 打赏
  • 举报
回复
dwWaitResult = (__UINT32)pthread_cond_timedwait(&infoX_Event.cv, &infoX_Event.mp, &abst);
这句前面应该加锁pthread_mutex_lock(&infoX_Event.mp);
因为在pthread_cond_timedwait函数内部是先执行解锁的
qq120848369 2012-03-08
  • 打赏
  • 举报
回复
它根本不会被信号中断, 你之所以无限循环肯定是走了continue分支, 自己研究以下把.

23,124

社区成员

发帖
与我相关
我的任务
社区描述
Linux/Unix社区 应用程序开发区
社区管理员
  • 应用程序开发区社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧