命名空间
变体
操作

std::move_only_function

来自 cppreference.com
< cpp‎ | utility‎ | functional
 
 
实用程序库
语言支持
类型支持 (基本类型,RTTI)
库功能测试宏 (C++20)
动态内存管理
程序实用程序
协程支持 (C++20)
可变参数函数
调试支持
(C++26)
三方比较
(C++20)
(C++20)(C++20)(C++20)
(C++20)(C++20)(C++20)
通用实用程序
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中已弃用)
整数比较函数
(C++20)(C++20)(C++20)   
(C++20)
交换类型操作
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
通用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
基本字符串转换
(C++17)
(C++17)

 
函数对象
函数包装器
(C++11)
move_only_function
(C++23)
(C++11)
函数调用
(C++17)(C++23)
恒等函数对象
(C++20)
透明运算符包装器
(C++14)
(C++14)
(C++14)
(C++14)  
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)

旧绑定器和适配器
(直到 C++17*)
(直到 C++17*)
(直到 C++17*)
(直到 C++17*)  
(直到 C++17*)
(直到 C++17*)(直到 C++17*)(直到 C++17*)(直到 C++17*)
(直到 C++20*)
(直到 C++20*)
(直到 C++17*)(直到 C++17*)
(直到 C++17*)(直到 C++17*)

(直到 C++17*)
(直到 C++17*)(直到 C++17*)(直到 C++17*)(直到 C++17*)
(直到 C++20*)
(直到 C++20*)
 
 
定义在头文件 <functional>
template< class... >
class move_only_function; // 未定义
(1) (自 C++23 起)
template< class R, class... Args >

class move_only_function<R(Args...)>;
template< class R, class... Args >
class move_only_function<R(Args...) noexcept>;
template< class R, class... Args >
class move_only_function<R(Args...) &>;
template< class R, class... Args >
class move_only_function<R(Args...) & noexcept>;
template< class R, class... Args >
class move_only_function<R(Args...) &&>;
template< class R, class... Args >
class move_only_function<R(Args...) && noexcept>;
template< class R, class... Args >
class move_only_function<R(Args...) const>;
template< class R, class... Args >
class move_only_function<R(Args...) const noexcept>;
template< class R, class... Args >
class move_only_function<R(Args...) const &>;
template< class R, class... Args >
class move_only_function<R(Args...) const & noexcept>;
template< class R, class... Args >
class move_only_function<R(Args...) const &&>;
template< class R, class... Args >

class move_only_function<R(Args...) const && noexcept>;
(2) (自 C++23 起)

类模板 std::move_only_function 是一个通用的多态函数包装器。std::move_only_function 对象可以存储和调用任何可构造的(不需要是可移动构造的)Callable 目标 - 函数、lambda 表达式bind 表达式 或其他函数对象,以及指向成员函数的指针和指向成员对象的指针。

存储的可调用对象称为 std::move_only_function目标。如果 std::move_only_function 不包含目标,则称为。与 std::function 不同,调用 std::move_only_function会导致未定义行为。

std::move_only_function 支持在模板参数中提供的每种可能的 cv 限定符引用限定符noexcept 说明符 组合,不包括 volatile。这些限定符和说明符(如果有)将被添加到其 operator() 中。

std::move_only_function 满足 可移动构造可移动赋值 的要求,但不满足 可复制构造可复制赋值 的要求。

内容

[编辑] 成员类型

类型 定义
result_type R

[编辑] 成员函数

构造一个新的 std::move_only_function 对象
(公共成员函数) [编辑]
销毁一个 std::move_only_function 对象
(公共成员函数) [编辑]
替换或销毁目标
(公共成员函数) [编辑]
交换两个 std::move_only_function 对象的目标
(公共成员函数) [编辑]
检查 std::move_only_function 是否有目标
(公共成员函数) [编辑]
调用目标
(公共成员函数) [编辑]

[编辑] 非成员函数

专门化 std::swap 算法
(函数) [编辑]
std::move_only_functionnullptr 进行比较
(函数) [编辑]

[编辑] 备注

实现可能会将大小较小的可调用对象存储在 std::move_only_function 对象中。这种小型对象优化对于函数指针和 std::reference_wrapper 专门化是有效需要的,并且只能应用于类型 T,对于这些类型 std::is_nothrow_move_constructible_v<T>true

如果一个返回引用的 std::move_only_function 从返回右值的函数或函数对象(包括没有尾随返回类型的 lambda 表达式)初始化,程序将是格式错误的,因为禁止将返回的引用绑定到临时对象。另见 std::function 备注。

特性测试 Std 特性
__cpp_lib_move_only_function 202110L (C++23) std::move_only_function

[编辑] 示例

#include <functional>
#include <future>
#include <iostream>
 
int main()
{
    std::packaged_task<double()> packaged_task([](){ return 3.14159; });
 
    std::future<double> future = packaged_task.get_future();
 
    auto lambda = [task = std::move(packaged_task)]() mutable { task(); };
 
//  std::function<void()> function = std::move(lambda); // Error
    std::move_only_function<void()> function = std::move(lambda); // OK
 
    function();
 
    std::cout << future.get();
}

输出

3.14159

[编辑] 参见

(C++11)
任何可复制构造的可调用对象的可复制包装器
(类模板) [编辑]