命名空间
变体
操作

std::function_ref 的推导指南

来自 cppreference.com
 
 
工具库
语言支持
类型支持 (基本类型, 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++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 F >
function_ref( F* ) -> function_ref<F>;
(1) (自 C++26 起)
template< auto f >
function_ref( std::nontype_t<f> ) -> function_ref</*见下文*/>;
(2) (自 C++26 起)
template< auto f, class T >
function_ref( std::nontype_t<f>, T&& ) -> function_ref</*见下文*/>;
(3) (自 C++26 起)
1) 仅当 std::is_function_v<F>true 时,此重载才参与重载解析。
2) 令类型 Fstd::remove_pointer_t<decltype(f)>。仅当 std::is_function_v<F>true 时,此重载才参与重载解析。推断的类型为 std::function_ref<F>
3) 令类型 Fdecltype(f)。此重载仅在以下情况下才参与重载解析:
  • F 的形式为 R(G::*)(A...) noexcept(E) (可选地进行 cv 限定,可选地进行 noexcept 限定,可选地进行左值引用限定)用于类型 G,或
  • F 的形式为 M G::* 用于类型 G 和对象类型 M,在这种情况下令 Rstd::invoke_result_t<F, T&>A... 为一个空包,且 E 为 false,或
  • F 的形式为 R(*)(G, A...) noexcept(E) 用于类型 G
推断的类型是 std::function_ref<R(A...) noexcept(E)>.

[编辑] 示例