>我正在运行一个带有openmp静态负载平衡的for循环。我想打印每个线程处理的第一个和最后一个迭代(又名 i
的第一个和最后一个值,对于每个线程(。循环如下所示:
#pragma omp parallel for schedule(static) private(i)
for(i=0;i<n;i++){
//loop code
}
我很清楚 OpenMP 文档指定了要在静态计划中平均划分的迭代范围,尽管我想打印迭代值。
只要记住初始化为标记值 (-1( 的私有变量中的索引:
#pragma omp parallel
{
int index = -1;
#pragma omp for schedule(static)
for(int i=0; i<n; i++){
//loop code
if (index == -1) {
printf("%d: start %dn", omp_get_thread_num(), i);
}
index = i;
}
printf("%d: last %dn", omp_get_thread_num(), index);
}