std::scoped_lock<MutexTypes...>::scoped_lock

来自cppreference.com
< cpp‎ | thread‎ | scoped lock
 
 
并发支持库
线程
(C++11)
(C++20)
(C++20)
this_thread 命名空间
(C++11)
(C++11)
(C++11)
互斥
(C++11)
(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++26)
风险指针





原子类型
(C++11)
(C++20)
原子类型的初始化
(C++11)(C++20 中弃用)
(C++11)(C++20 中弃用)
内存定序
原子操作的自由函数
原子标志的自由函数
 
std::scoped_lock
成员函数
scoped_lock::scoped_lock
 
explicit scoped_lock( MutexTypes&... m );
(1) (C++17 起)
scoped_lock( std::adopt_lock_t, MutexTypes&... m );
(2) (C++17 起)
scoped_lock( const scoped_lock& ) = delete;
(3) (C++17 起)

取得各给定互斥体 m 的所有权。

1)sizeof...(MutexTypes) == 0 则不做任何事。否则若 sizeof...(MutexTypes) == 1,则相当于调用 m.lock()。否则,相当于调用 std::lock(m...)
2) 取得各互斥体 m... 的所有权而不尝试锁定任何互斥体。除非当前线程在 m... 中的每个对象上保有一个非共享锁(即以 locktry_locktry_lock_fortry_lock_until 取得的锁),否则行为未定义。
3) 复制构造函数被弃置。

mscoped_lock 对象之前被销毁,则行为未定义。

参数

m - 要获得所有权的各互斥体

异常

1) 抛出 m.lock() 所抛的任何异常。
2) 不抛出。

缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 出版时的行为 正确行为
P0739R0 C++17 adopt_lock_t 参数在最后,妨碍类模板实参推导 移到最前