std::recursive_mutex
来自 cppreference.com
在头文件 <mutex> 中定义 |
||
class recursive_mutex; |
(自 C++11 起) | |
recursive_mutex
类是一种同步原语,可用于保护共享数据不被多个线程同时访问。
recursive_mutex
提供排他性、递归所有权语义
- 调用线程在成功调用
lock
或try_lock
后,便拥有recursive_mutex
一段时间。在此期间,线程可以对lock
或try_lock
进行额外调用。所有权期间结束时,线程会对unlock
进行相同次数的调用。 - 当线程拥有
recursive_mutex
时,如果其他线程尝试获取recursive_mutex 的所有权,则所有其他线程将被阻塞(对于
lock
的调用)或返回 false 值(对于try_lock
)。 recursive_mutex
可以被锁定的最大次数未指定,但超过该次数后,对lock
的调用将抛出 std::system_error,对try_lock
的调用将返回 false。
如果在某个线程仍拥有 recursive_mutex 时销毁了该
recursive_mutex,则程序的行为未定义。
recursive_mutex
类满足 Mutex 和 StandardLayoutType 的所有要求。
内容 |
[编辑] 成员类型
成员类型 | 定义 |
native_handle_type (可选*) |
实现定义的 |
[编辑] 成员函数
构造互斥体 (公有成员函数) | |
销毁互斥体 (公有成员函数) | |
operator= [已删除] |
不可复制赋值 (公有成员函数) |
锁定 | |
锁定互斥体,如果互斥体不可用,则会阻塞 (公有成员函数) | |
尝试锁定互斥体,如果互斥体不可用,则返回 (公有成员函数) | |
解锁互斥体 (公有成员函数) | |
原生句柄 | |
返回底层的实现定义的原生句柄对象 (公有成员函数) |
[编辑] 示例
recursive_mutex 的一种用例是保护类中成员函数的共享状态,这些成员函数可能会相互调用。
运行此代码
#include <iostream> #include <mutex> #include <thread> class X { std::recursive_mutex m; std::string shared; public: void fun1() { std::lock_guard<std::recursive_mutex> lk(m); shared = "fun1"; std::cout << "in fun1, shared variable is now " << shared << '\n'; } void fun2() { std::lock_guard<std::recursive_mutex> lk(m); shared = "fun2"; std::cout << "in fun2, shared variable is now " << shared << '\n'; fun1(); // recursive lock becomes useful here std::cout << "back in fun2, shared variable is " << shared << '\n'; } }; int main() { X x; std::thread t1(&X::fun1, &x); std::thread t2(&X::fun2, &x); t1.join(); t2.join(); }
可能的输出
in fun1, shared variable is now fun1 in fun2, shared variable is now fun2 in fun1, shared variable is now fun1 back in fun2, shared variable is fun1
[编辑] 另请参阅
(C++11) |
提供基本互斥功能 (类) |