要并行调用一个具有向量参数的向量元素的成员函数,可以使用并行编程库,如OpenMP或CUDA。以下是使用OpenMP的示例代码:
#include
#include
#include
class MyClass {
public:
void foo(int x) {
std::cout << "Thread " << omp_get_thread_num() << ": " << x << std::endl;
}
};
int main() {
std::vector input = {1, 2, 3, 4, 5};
std::vector objects(input.size());
#pragma omp parallel for
for (int i = 0; i < input.size(); i++) {
objects[i].foo(input[i]);
}
return 0;
}
在上面的示例中,我们定义了一个名为MyClass
的类,它具有一个名为foo
的成员函数,该函数接受一个整数参数。我们还创建了一个存储整数的向量input
和一个具有相同大小的MyClass
对象的向量objects
。
使用#pragma omp parallel for
指令,我们可以并行调用foo
函数。omp_get_thread_num()
函数用于获取当前线程的编号,以便在输出中显示线程号。
在运行上述代码时,我们可以看到每个线程都会并行调用foo
函数,每个线程负责处理一个输入元素。输出可能会因为线程并行执行而发生交错,但仍然可以看到每个线程按照顺序处理输入元素。