并行编程是现代计算机科学中的一个重要主题,它允许我们利用多核处理器的能力,同时执行多个任务,从而提高程序的性能。在C++中,我们可以使用多种机制来实现并行编程,其中之一就是std::packaged_task。在本文中,我们将探讨如何使用std::packaged_task进行任务并行化。
std::packaged_task简介
std::packaged_task是C++标准库中的一个类模板,它是一个通用的可调用对象包装器,可以用于将任务与其结果关联起来。std::packaged_task将一个可调用对象包装起来,以便在一个线程中执行,然后在另一个线程中获取结果。
std::packaged_task的一个重要特性是它可以与std::future一起使用,以实现异步计算。当我们创建一个std::packaged_task时,它会创建一个std::future,我们可以使用这个std::future来获取任务的结果。
以下是一个使用std::packaged_task的例子:
#include <future>
#include <iostream>
int main() {
std::packaged_task<int(int, int)> task([](int a, int b) { return a + b; });
std::fu