名稱空間
變體
操作

std::function_ref 的推導指南

來自 cppreference.com
 
 
 
函式物件
函式呼叫
(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-qualified,可選 noexcept,可選左值引用 qualified),其中 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)>

[編輯] 示例