std::packaged_task 的推导指引

来自cppreference.com


 
 
并发支持库
线程
(C++11)
(C++20)
(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++11)
信号量
闩与屏障
(C++20)
(C++20)
未来体
(C++11)
(C++11)
(C++11)
(C++11)
安全回收
(C++26)
(C++26)
风险指针





原子类型
(C++11)
(C++20)
原子类型的初始化
(C++11)(C++20 中弃用)
(C++11)(C++20 中弃用)
内存定序
原子操作的自由函数
原子标志的自由函数
 
 
在标头 <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)>
}