std::move_only_function::operator=
来自cppreference.com
                    
                                        
                    < cpp | utility | functional | move only function
                    
                                                            
                    |   move_only_function& operator=( move_only_function&& other );  | 
(1) | (C++23 起) | 
|   move_only_function& operator=( const move_only_function& ) = delete;  | 
(2) | (C++23 起) | 
|   move_only_function& operator=( std::nullptr_t ) noexcept;  | 
(3) | (C++23 起) | 
|   template< class F >  move_only_function& operator=( F&& f );  | 
(4) | (C++23 起) | 
指派新目标给 std::move_only_function 或销毁其目标。
1) 通过 auto(std::move(other)).swap(*this) 移动 
other 的目标给 *this 或若 other 为空则销毁 *this 的目标(若存在)。移动赋值后 other 在有未指定值的合法状态。3) 若当前目标存在则销毁它。调用后 *this 为空。
4) 如同通过执行 move_only_function(std::forward<F>(f)).swap(*this); 设置 *this 的目标为可调用对象 
f ,或若 f 为空函数指针、空成员函数指针或空 std::move_only_function 则销毁当前目标。此重载只有在 move_only_function 源自 F 的构造函数参与重载决议时才会参与重载决议。若选择的构造函数调用非良构或有未定义行为,则程序非良构或有未定义行为。参数
| other | - |   要移动目标的 std::move_only_function 对象
 | 
| f | - | 用以初始化新目标的可调用对象 | 
返回值
*this
注解
有意不要求移动赋值运算符为 noexcept ,以为将来的知分配器的 move_only_function 留出余地。
只要能从 std::in_place_type<Fn> 构造 move_only_function ,就能用该参数赋值它。
参阅
|    为内容赋值  ( std::function<R(Args...)> 的公开成员函数)  |