Студопедия — Директива параллельного цикла
Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Директива параллельного цикла






Директива относится только к циклу, непосредственно следующему за ней:

#pragma omp parallel

{

...

#pragma omp for [опции]

for(...)

{

}

...

}

Если в параллельной области есть только один блок — сам цикл, тогда

директива может использовать сокращенную форму:

#pragma omp parallel for [опции]

for(...)

{

}

Пример использование параллельного цикла

#include <stdio.h>

#include <omp.h>

int main(int argc, char *argv[])

{

int A[10], B[10], C[10], i, n;

/* Заполним исходные массивы */

for (i=0; i<10; i++){ A[i]=i; B[i]=2*i; C[i]=0; }

#pragma omp parallel shared(A, B, C) private(i, n)

{

/* Получим номер текущей нити */

n=omp_get_thread_num();

#pragma omp for

for (i=0; i<10; i++)

{

C[i]=A[i]+B[i];

printf("Нить %d сложила элементы с номером %d\n",n, i);

}

}

}

Директива sections

Директива sections используется для назначения каждому потоку своей

задачи:

#pragma omp parallel sections

{

#pragma omp section

{

// код первой ветви

dosmth1();

}

#pragma omp section

{

// код второй ветви

dosmth2();

}

}

 

Барьер:

#pragma omp barrier

Критическая секция:

#pragma omp critical [(<имя критической секции>)]

Пример использования критической секции:

#include <stdio.h>

#include <omp.h>

int main(int argc, char *argv[])

{

int n;

#pragma omp parallel

{

#pragma omp critical

{

n=omp_get_thread_num();

printf("Нить %d\n", n);

}

}

}







Дата добавления: 2015-08-12; просмотров: 356. Нарушение авторских прав; Мы поможем в написании вашей работы!



Важнейшие способы обработки и анализа рядов динамики Не во всех случаях эмпирические данные рядов динамики позволяют определить тенденцию изменения явления во времени...

ТЕОРЕТИЧЕСКАЯ МЕХАНИКА Статика является частью теоретической механики, изучающей условия, при ко­торых тело находится под действием заданной системы сил...

Теория усилителей. Схема Основная масса современных аналоговых и аналого-цифровых электронных устройств выполняется на специализированных микросхемах...

Логические цифровые микросхемы Более сложные элементы цифровой схемотехники (триггеры, мультиплексоры, декодеры и т.д.) не имеют...

Измерение следующих дефектов: ползун, выщербина, неравномерный прокат, равномерный прокат, кольцевая выработка, откол обода колеса, тонкий гребень, протёртость средней части оси Величину проката определяют с помощью вертикального движка 2 сухаря 3 шаблона 1 по кругу катания...

Неисправности автосцепки, с которыми запрещается постановка вагонов в поезд. Причины саморасцепов ЗАПРЕЩАЕТСЯ: постановка в поезда и следование в них вагонов, у которых автосцепное устройство имеет хотя бы одну из следующих неисправностей: - трещину в корпусе автосцепки, излом деталей механизма...

Понятие метода в психологии. Классификация методов психологии и их характеристика Метод – это путь, способ познания, посредством которого познается предмет науки (С...

Шов первичный, первично отсроченный, вторичный (показания) В зависимости от времени и условий наложения выделяют швы: 1) первичные...

Предпосылки, условия и движущие силы психического развития Предпосылки –это факторы. Факторы психического развития –это ведущие детерминанты развития чел. К ним относят: среду...

Анализ микросреды предприятия Анализ микросреды направлен на анализ состояния тех со­ставляющих внешней среды, с которыми предприятие нахо­дится в непосредственном взаимодействии...

Studopedia.info - Студопедия - 2014-2024 год . (0.01 сек.) русская версия | украинская версия