Sdílet prostřednictvím


ordered (direktivy OpenMP)

Určuje kód pod parallelized smyčka by spouštěn jako sekvenční smyčky.

#pragma omp ordered
   structured-block

Poznámky

Objednané směrnice musí být v rámci dynamického rozsahu for (OpenMP) nebo pro paralelní konstrukce s objednané klauzule.

Objednané směrnice podporuje žádná klauzule OpenMP.

Další informace naleznete v tématu 2.6.6 ordered – konstrukce.

Příklad

// omp_ordered.cpp
// compile with: /openmp 
#include <stdio.h>
#include <omp.h>

static float a[1000], b[1000], c[1000];

void test(int first, int last) 
{
    #pragma omp for schedule(static) ordered
    for (int i = first; i <= last; ++i) {
        // Do something here.
        if (i % 2) 
        {
            #pragma omp ordered 
            printf_s("test() iteration %d\n", i);
        }
    }
}

void test2(int iter) 
{
    #pragma omp ordered
    printf_s("test2() iteration %d\n", iter);
}

int main( ) 
{
    int i;
    #pragma omp parallel
    {
        test(1, 8);
        #pragma omp for ordered
        for (i = 0 ; i < 5 ; i++)
            test2(i);
    }
}
  

Viz také

Referenční dokumentace

Direktivy jazyka OpenMP