为指令嵌套A.18

嵌套 for 指令的下面的示例 (在第 33 页) 的第2.9部分 是兼容的,因为内部和外部 for 指令绑定到不同的并行区域:

#pragma omp parallel default(shared)
{
    #pragma omp for
        for (i=0; i<n; i++) 
        {
            #pragma omp parallel shared(i, n)
            {
                #pragma omp for
                    for (j=0; j<n; j++)
                        work(i, j);
            }
        }
}

前面示例的以下变体也是兼容的:

#pragma omp parallel default(shared)
{
    #pragma omp for
        for (i=0; i<n; i++)
            work1(i, n);
}

void work1(int i, int n)
{
    int j;
    #pragma omp parallel default(shared)
    {
        #pragma omp for
            for (j=0; j<n; j++)
                work2(i, j);
    }
    return;
}