std::unique_lock<Mutex>::operator=

来自cppreference.com
< cpp‎ | thread‎ | unique 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 中弃用)
内存定序
原子操作的自由函数
原子标志的自由函数
 
 
unique_lock& operator=( unique_lock&& other );
(C++11 起)

移动赋值运算符。用移动语义以 other 的内容替换内容。

如果调用前 *this 拥有关联互斥体并获得了它的所有权,那么解锁互斥体。

参数

other - 以之替换状态的另一 unique_lock

返回值

*this

异常

不抛出。

注解

一个递归互斥体可能使得 *thisother 在赋值时同时持有同一个互斥体。这种情况下,在赋值后,*this 将持有锁,而 other 将不会。

缺陷报告

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

缺陷报告 应用于 出版时的行为 正确行为
LWG 2104 C++11 移动赋值运算符是 noexcept 的,但在行为未定义的情况下它可能会抛出异常[1] 它不是 noexcept
  1. 例如 *thisstd::adopt_lock 构造,但调用线程并没有关联互斥的所有权。此时 *this 无法正常释放关联互斥的所有权,并且可能导致异常抛出。