如何使用boost实现一个跨越多个方法的递归锁
How can implement a recursive lock using boost, that spans multiple methods?
我有一个类,它打开事务,向队列添加操作,然后关闭事务。在整个open->close生命周期中,我希望使用递归互斥锁,这样在任何时候只有一个线程可以打开事务。所有其他线程被阻塞,直到当前事务结束。
class MyObject
{
void beginTransaction()
{
// acquire mutex
}
void endTransaction()
{
// release mutex
}
boost::recursive_mutex m_mutex;
}
在这种情况下,我很难确定如何使用recursive_mutex
,因为锁的存在时间比单个方法的作用域长。有人能告诉我如何在这里应用锁吗?
Boost(和标准库)提供互斥锁,可以锁定和解锁;锁,在构造函数中锁定互斥锁,在析构函数中解锁。锁实际上只是轻量级的包装器,用于确保锁在离开作用域时被释放。
在您的例子中,您可以直接使用互斥锁,而不必将其封装在锁中。
可以调用beginTransaction
中的m_mutex.lock()
来锁定互斥锁,然后调用endTransaction
中的m_mutex.unlock()
来解锁互斥锁。如果另一个线程试图在调用之间调用m_mutex.lock()
,它将阻塞,直到拥有endTransaction
的线程解锁互斥锁
相关文章:
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- 通过方法访问结构
- 最小硬币更换问题(自上而下方法)
- C++为构建时间获取QDateTime的可靠方法
- 在C#中处理C++指针而不使用unsafe的最佳方法
- 处理多个异常集合的C++方法
- 如果C++类在类方法中具有动态分配,但没有构造函数/析构函数或任何非静态成员,那么它仍然是POD类型吗
- 有什么方法可以遍历结构吗
- 当类在C++中定义时,有什么方法可以"register"类吗?
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 实现无开销push_back的最佳方法是什么
- 使用std::函数映射对象方法
- 有符号的int和int-有没有一种方法可以在C++中区分它们
- C++从另一个类访问公共静态向量的正确方法是什么
- C++优先级队列,按对象的唯一指针的特定方法升序排列
- 没有为自己的结构调用列表推回方法
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- x86-64上检查指针范围是否跨越N字节对齐地址的最快方法
- 跨越COM方法边界的C++异常会发生什么
- 如何使用boost实现一个跨越多个方法的递归锁