Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Скачиваний:
37
Добавлен:
19.04.2015
Размер:
1.35 Mб
Скачать

Текст программы:

14

Дальнейшая настройка

15

Дальнейшая настройка

16

Новый результат:

17

Задание:

1) измените параметр, например

omp_set_num_threads( 10 );

2) Закомментируйте эту строку. Какие будут результаты?

Какого числа тредов удалось добиться?

Пример: вывод номера треда

18

Переменные. Локализация (область видимости)

19

Модель данных в OpenMP:

 

общая область памяти - для всех тредов,

локальные области памяти - для каждого треда.

тред

Память

треда

тред

Память

треда

ОБЩАЯ

ПАМЯТЬ

20

Переменные. Локализация (область видимости)

Переменные, использующиеся в параллельных областях

программы, разделяются на два основных класса:

shared общие

все треды видят одну и ту же переменную;

private - локальные

каждый тред видит свой экземпляр данной переменной,

создаются для каждого треда только на время

его выполнения.

21

Переменные. Локализация (область видимости)

Правила видимости переменных:

все переменные, определенные вне параллельной области –

общие;

все переменные, определенные внутри параллельной области –

локальные

Пример: локализация переменных

22

глобальн

ая

локальна

я

Директивы OpenMP - parallel

23

Основная директива для создания параллельной области

 

int main ()

{

//последовательная область, выполняется корневой тред

. . .

//Начало параллельной области

#pragma omp parallel [опции]

{

//операторы выполняются всеми тредами

. . .

//все треды завершают работу, остается только корневой тред

}

//последовательная область, выполняется корневой тред

. . .

}

Соседние файлы в папке Параллельное программирование (лекции)