std::function<R(Args...)>::operator=
< cpp | utility | functional | function
function& operator=( const function& other );
|
(1) | (C++11 起) |
function& operator=( function&& other );
|
(2) | (C++11 起) |
function& operator=( std::nullptr_t ) noexcept;
|
(3) | (C++11 起) |
template< class F >
function& operator=( F&& f ); |
(4) | (C++11 起) |
template< class F >
function& operator=( std::reference_wrapper<F> f ) noexcept; |
(5) | (C++11 起) |
赋值新目标给 std::function
。
1) 赋值
other
的目标副本,如同以执行 function(other).swap(*this);2) 移动
other
的目标到 *this。other
处于具有未指定值的合法状态。3) 舍弃当前目标。*this 在调用后为空。
4) 设置 *this 的目标为可调用的
f
,如同以执行 function(std::forward<F>(f)).swap(*this);。此运算符不参与重载决议,除非 f
对于实参类型 Args...
和返回类型 R
可调用 (Callable) 。5) 设置 *this 的目标为
f
的副本,如同以执行 function(f).swap(*this);参数
other | - | 要复制其目标的另一 std::function 对象 |
f | - | 用以初始化目标的可调用物 |
类型要求 | ||
-
F 必须满足可调用 (Callable) 。 |
返回值
*this
注解
即便在 C++17 中从 std::function
移除分配器支持之前,这些赋值运算符使用的也是默认分配器,而不是 *this 或 other
的分配器(见 LWG 问题 2386)。
缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
缺陷报告 | 应用于 | 出版时的行为 | 正确行为 |
---|---|---|---|
LWG 2132 | C++11 | 接收一个可调用 (Callable) 对象的重载可能有歧义 | 已约束 |
LWG 2401 | C++11 | 未要求源自 std::nullptr_t 的构造函数为 noexcept |
已要求 |
参阅
替换或销毁目标 ( std::move_only_function 的公开成员函数) |
|
(C++17 中移除)
|
赋值新的目标 (公开成员函数) |