std::packaged_task 的推导指引

出自cppreference.com


 
 
並發支持庫
線程
(C++11)
(C++20)
this_thread 命名空間
(C++11)
(C++11)
(C++11)
協作式取消
互斥
(C++11)
通用鎖管理
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
條件變數
(C++11)
信號量
閂與屏障
(C++20)
(C++20)
未來體
(C++11)
(C++11)
(C++11)
(C++11)
安全回收
(C++26)
風險指針
原子類型
(C++11)
(C++20)
原子類型的初始化
(C++11)(C++20 棄用)
(C++11)(C++20 棄用)
內存定序
(C++11)(C++26 棄用)
原子操作的自由函數
原子標誌的自由函數
 
 
在標頭 <future> 定義
template< class R, class... Args >
packaged_task( R(*)(Args...) ) -> packaged_task<R(Args...)>;
(1) (C++17 起)
template< class F >
packaged_task( F ) -> packaged_task</* 見下文 */>;
(2) (C++17 起)
template< class F >
packaged_task( F ) -> packaged_task</* 見下文 */>;
(3) (C++23 起)
template< class F >
packaged_task( F ) -> packaged_task</* 見下文 */>;
(4) (C++23 起)
1)std::packaged_task 提供此推導指引以允許從函數推導。
2) 此重載只有在 &F::operator() 在作為不求值操作數時為良構且 decltype(&F::operator()) 的形式為 R(G::*)(A...)(可選地有 cv 限定,可選地有 noexcept,可選地有左值引用限定)而 G 為類類型時才會參與重載決議。推導類型為 std::packaged_task<R(A...)>
3) 此重載只有在 &F::operator() 在作為不求值操作數時為良構且 F::operator() 是具有形式為 R(G, A...)R(G, A...) noexcept 的類型的顯式對象形參函數時才會參與重載決議。推導的類型為 std::packaged_task<R(A...)>
4) 此重載只有在 &F::operator() 在作為不求值操作數時為良構且 F::operator() 是具有形式為 R(A...)R(A...) noexcept 的類型的靜態成員函數時才會參與重載決議。推導的類型為 std::packaged_task<R(A...)>

[編輯] 註解

這些推導指引不允許從帶省略號形參的函數推導,而類型中的 ... 始終被當做包展開

[編輯] 示例

#include <future>
 
int func(double) { return 0; }
 
int main()
{
    std::packaged_task f{func}; // 推导出 packaged_task<int(double)>
 
    int i = 5;
    std::packaged_task g = [&](double) { return i; }; // 推导出 packaged_task<int(double)>
}