std::function::operator=

来自cppreference.com
< cpp‎ | utility‎ | functional‎ | function
 
 
工具库
类型支持(基本类型、 RTTI 、类型特性)
动态内存管理
错误处理
程序工具
变参数函数
日期和时间
函数对象
(C++11)
关系运算符
optionalanyvariant (C++17)
pair 与 tuple
(C++11)
(C++17)
swap 、 forward 与 move
(C++14)
(C++11)
(C++11)
初等字符串转换
(C++17)
(C++17)
类型运算
(C++11)
(C++17)
 
函数对象
函数包装
(C++11)
(C++11)
绑定
(C++11)
函数调用
(C++17)
引用包装
(C++11)
(C++11)
运算符包装
取反器
(弃用)
(弃用)

(弃用)
搜索器
旧绑定器与适配器
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)

(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)
 
 
function& operator=( const function& other );
(1) (C++11 起)
function& operator=( function&& other );
(2) (C++11 起)
function& operator=( std::nullptr_t );
(3) (C++11 起)
template< class F >
function& operator=( F&& f );
(4) (C++11 起)
template< class F >
function& operator=( std::reference_wrapper<F> f );
(5) (C++11 起)

赋值新目标std::function

1) 赋值 other目标副本,如同以执行 function(other).swap(*this);
2) 移动 other目标*thisother 在有未指定值的合法状态。
3) 舍弃当前目标*this 在调用后为
4) 设置 *this目标为可调用的 f ,如同以执行 function(std::forward<F>(f)).swap(*this);此运算符不参与重载决议,除非 f 对于参数类型 Args... 和返回类型 R 可调用 (Callable) 。 (C++14 起)
5) 设置 *this目标f 的副本,如同以执行 function(f).swap(*this);

目录

[编辑] 参数

other - 要复制其目标的另一 std::function 对象
f - 用以初始化目标的可调用对象
类型要求
-
F 必须满足 Callable 的要求。

[编辑] 返回值

*this

[编辑] 异常

1-2) (无)
3)

(无)

(C++17 前)
noexcept 规定:  
noexcept
  
(C++17 起)
4) (无)
5)
noexcept 规定:  
noexcept
  

[编辑] 注意

虽然 C++17 中从 std::function 移除了以前的分配器支持,这些赋值运算符使用默认分配器,而不是 *thisother 的分配器(见 LWG #2386 )。

[编辑] 参阅

为内容赋值一个新的目标
(公开成员函数) [编辑]