std::packaged_task<R(Args...)>::packaged_task

来自cppreference.com
 
 
并发支持库
线程
(C++11)
(C++20)
(C++20)
this_thread 命名空间
(C++11)
(C++11)
(C++11)
原子类型
(C++11)
(C++20)
原子类型的初始化
(C++11)(C++20 中弃用)
(C++11)(C++20 中弃用)
原子操作的自由函数
原子标志的自由函数
内存序
互斥
(C++11)
通用锁管理
(C++11)
(C++11)
(C++11)
(C++11)(C++11)(C++11)
(C++11)
(C++11)
条件变量
(C++11)
信号量
闩与屏障
(C++20)
(C++20)
future
(C++11)
(C++11)
(C++11)
(C++11)
 
 
packaged_task() noexcept;
(1) (C++11 起)
template <class F>
explicit packaged_task( F&& f );
(2) (C++11 起)
template <class F, class Allocator>
explicit packaged_task( std::allocator_arg_t, const Allocator& a, F&& f );
(3) (C++11 起)
(C++17 前)
packaged_task( const packaged_task& ) = delete;
(4) (C++11 起)
packaged_task( packaged_task&& rhs ) noexcept;
(5) (C++11 起)

构造新的 std::packaged_task 对象。

1) 构造无任务且无共享状态的 std::packaged_task 对象。
2) 构造拥有共享状态和任务副本的 std::packaged_task 对象,以 std::forward<F>(f) 初始化副本。若 std::decay<F>::typestd::packaged_task<R(ArgTypes...)> 是同一类型,则此构造函数不参与重载决议。
3) 构造拥有共享状态和任务副本的 std::packaged_task 对象,以 std::forward<F>(f) 初始化副本。用分配器 a 分配存储任务所需的内存。 (C++17 前)
  • std::decay<F>::typestd::packaged_task<R(ArgTypes...)> 为同一类型则这些 (C++17 前) (C++17 起)构造函数不参与重载决议。
  • INVOKE<R>(std::forward<F>(f), std::declval<Args>()...) 表达式(描述于可调用 (Callable) )在作为不求值操作数时非良构(即 std::is_invocable_r_v<R, F, Args...>true (C++17 起),则程序非良构。
  • 若在 f 的副本上的调用表现异于在 f 上的调用,则行为未定义。
4) 复制构造函数被删除, std::packaged_task 仅可移动。
5)rhs 之前所占有的共享状态和任务构造 std::packaged_task ,令 rhs 留在无共享状态且拥有被移动后的任务的状态。

参数

f - 要执行的可调用目标(函数、成员函数、 lambda 表达式、函数对象)
a - 存储任务时所用的分配器
rhs - 要移动的 std::packaged_task

异常

2) f 的复制/移动构造函数所抛的任何异常,而若内存分配失败则可能为 std::bad_alloc
3) f 的复制/移动构造函数,而若内存分配失败则有分配器的 allocate 函数所抛的任何异常。

示例

#include <future>
#include <iostream>
#include <thread>
 
int fib(int n)
{
    if (n < 3) return 1;
    else return fib(n-1) + fib(n-2);
}
 
int main()
{
    std::packaged_task<int(int)> fib_task(&fib); 
 
    std::cout << "starting task\n";
    auto result = fib_task.get_future();
    std::thread t(std::move(fib_task), 42);
 
    std::cout << "waiting for task to finish..." << std::endl;
    std::cout << result.get() << '\n';
 
    std::cout << "task complete\n";
    t.join();
}

输出:

starting task
waiting for task to finish...
267914296
task complete

缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 出版时的行为 正确行为
LWG 2067 C++11 被删除的复制构造函数接收非 const 引用 使之为 const