命名空间
变体
操作

std::recursive_mutex

来自 cppreference.com
< cpp‎ | thread
 
 
并发支持库
线程
(C++11)
(C++20)
this_thread 命名空间
(C++11)
(C++11)
(C++11)
协作取消
互斥
(C++11)
recursive_mutex
(C++11)
通用锁管理
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
条件变量
(C++11)
信号量
闩锁和屏障
(C++20)
(C++20)
期货
(C++11)
(C++11)
(C++11)
(C++11)
安全回收
(C++26)
危险指针
原子类型
(C++11)
(C++20)
原子类型的初始化
(C++11)(C++20 中已弃用)
(C++11)(C++20 中已弃用)
内存排序
用于原子操作的自由函数
用于原子标志的自由函数
 
 
在头文件 <mutex> 中定义
class recursive_mutex;
(自 C++11 起)

recursive_mutex 类是一种同步原语,可用于保护共享数据不被多个线程同时访问。

recursive_mutex 提供排他性、递归所有权语义

  • 调用线程在成功调用 locktry_lock 后,便拥有 recursive_mutex 一段时间。在此期间,线程可以对 locktry_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 类满足 MutexStandardLayoutType 的所有要求。

内容

[编辑] 成员类型

成员类型 定义
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)
提供基本互斥功能
(类) [编辑]