std::function
的推導指南
來自 cppreference.com
< cpp | utility | functional | function
定義於標頭檔案 <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 起) |
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() 具有 &&-限定 |
明確將其從過載決議中排除 |