进入互斥区的代码
{
boost::mutex::scoped_lock guard(m_lock);
.....
m_condition.wait(m_lock);
......
}
这里需要注意的是,当wait返回以后,guard已经失效了,不能够再安全地进行需要互斥的的操作了,为了争用操作的互斥,必须再次获得锁,类似:
do
{
boost::mutex::scoped_lock guard(m_lock);
.....
m_condition.wait(m_lock);
} while (some condition);
在这里犯了一次错误,谨记!
{
boost::mutex::scoped_lock guard(m_lock);
.....
m_condition.wait(m_lock);
......
}
这里需要注意的是,当wait返回以后,guard已经失效了,不能够再安全地进行需要互斥的的操作了,为了争用操作的互斥,必须再次获得锁,类似:
do
{
boost::mutex::scoped_lock guard(m_lock);
.....
m_condition.wait(m_lock);
} while (some condition);
在这里犯了一次错误,谨记!
本文详细解析了在使用Boost库中的互斥锁时容易犯的一个常见错误:在互斥区内使用条件变量等待后未重新获取锁导致的问题,并提供了解决方案。
422

被折叠的 条评论
为什么被折叠?



