名稱空間
變體
操作

std::function 的推導指南

來自 cppreference.com
< cpp‎ | utility‎ | functional‎ | function
 
 
 
函式物件
函式呼叫
(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 R, class... ArgTypes >
function( R(*)(ArgTypes...) ) -> function<R(ArgTypes...)>;
(1) (C++17 起)
template< class F >
function( F ) -> function</*參見下文*/>;
(2) (C++17 起)
template< class F >
function( F ) -> function</*參見下文*/>;
(3) (C++23 起)
template< class F >
function( F ) -> function</*參見下文*/>;
(4) (C++23 起)
1)std::function 提供了此推導指南,以允許從函式進行推導。
2) 僅當 &F::operator() 在被視為未求值運算元時格式良好,並且 decltype(&F::operator()) 的形式為 R(G::*)(A...)(可選 cv-qualified,可選 noexcept,可選左值引用 qualified)時,此過載才參與過載決議。推導型別為 std::function<R(A...)>
3) 僅當 &F::operator() 在被視為未求值運算元時格式良好,並且 F::operator()顯式物件引數函式,其型別為 R(G, A...)R(G, A...) noexcept 時,此過載才參與過載決議。推導型別為 std::function<R(A...)>
4) 僅當 &F::operator() 在被視為未求值運算元時格式良好,並且 F::operator()靜態成員函式,其型別為 R(A...)R(A...) noexcept 時,此過載才參與過載決議。推導型別為 std::function<R(A...)>

[編輯] 注意

這些推導指南不允許從帶有省略號引數的函式進行推導,並且型別中的 ... 始終被視為包擴充套件

這些推導指南推導的型別可能會在後續標準修訂中更改(特別是,如果後續標準將 noexcept 支援新增到 std::function 中,則可能會發生這種情況)。

[編輯] 示例

#include <functional>
int func(double) { return 0; }
int main() {
  std::function f{func}; // guide #1 deduces function<int(double)>
  int i = 5;
  std::function g = [&](double) { return i; }; // guide #2 deduces function<int(double)>
}

[編輯] 缺陷報告

下列更改行為的缺陷報告追溯地應用於以前出版的 C++ 標準。

缺陷報告 應用於 釋出時的行為 正確的行為
LWG 3238 C++17 (2) 的行為在以下情況下不明確:
F::operator() 具有 &&-限定
明確將其從過載決議中排除