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

来自cppreference.com
< cpp‎ | thread‎ | scoped lock
 
 
并发支持库
线程
(C++11)
(C++20)
this_thread 命名空间
(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++20)
原子类型的初始化
(C++11)(C++20 弃用)
(C++11)(C++20 弃用)
内存定序
(C++11)(C++26 弃用)
原子操作的自由函数
原子标志的自由函数
 
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++ 标准。

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