用C++多线程和Lambda函数实现并行计算
在当今高速发展的互联网时代,我们面临着海量数据的处理和计算需求。为了提高数据处理效率,我们需要采用多线程来进行并行计算。而C++中的Lambda函数可以很好地配合多线程一起使用,实现方便快捷的并行计算。
下面我们通过一个简单的例子来展示如何用C++多线程和Lambda函数实现并行计算。
首先,我们需要定义一个函数,作用是将整数序列中的每个元素都平方后返回一个新的序列:
std::vector<int> Square(const std::vector<int>& data)
{
std::vector<int> result(data.size());
std::transform(data.begin(), data.end(), result.begin(), [](int x) {return x * x; });
return result;
}
接下来,我们将该函数改写成Lambda表达式的形式,并利用多线程实现并行计算:
std::vector<int> ParallelSquare(const std::vector<int>& data)
{
const int num_threads = std::max(1, static_cast<int>(std::thread::hardware_concurrency()));
std