OpenMP는 공유 메모리 환경에서 병렬 프로그래밍을 지원하는 C, C++ 또는 FORTRAN으로 작성된 프로그램용 API 및 컴파일러 지시문 세트입니다. OpenMP는 병렬 영역을 병렬로 실행될 수 있는 코드 블록으로 식별합니다. 응용 프로그램 개발자는 병렬 영역의 코드에 컴파일러 지시문을 삽입하고 이러한 지시문은 OpenMP 런타임 라이브러리에 해당 영역을 병렬로 실행하도록 지시합니다. 다음 C 프로그램은 printf() 문을 포함하는 병렬 영역 위의 컴파일러 지시문을 보여줍니다. -
#include <omp.h> #include <stdio.h> int main(int argc, char *argv[]){ /* sequential code */ #pragma omp parallel{ printf("I am a parallel region."); } /* sequential code */ return 0; }
OpenMP가 지시문을 만났을 때
#pragma omp parallel
시스템에서 코어를 처리하는 스레드를 생성합니다. 따라서 듀얼 코어 시스템의 경우 두 개의 스레드가 생성되고 쿼드 코어 시스템의 경우 네 개의 스레드가 생성됩니다. 기타 등등. 그런 다음 모든 스레드가 동시에 병렬 영역을 실행합니다. 각 스레드가 병렬 영역을 나갈 때 종료됩니다. OpenMP는 루프 병렬화를 포함하여 병렬로 코드 영역을 실행하기 위한 몇 가지 추가 지시문을 제공합니다.
병렬화에 대한 지시문을 제공하는 것 외에도 OpenMP를 사용하면 개발자가 여러 수준의 병렬화 중에서 선택할 수 있습니다. 예를 들어 스레드 수를 수동으로 설정할 수 있습니다. 또한 개발자는 데이터가 스레드 간에 공유되는지 또는 스레드에 대해 비공개인지 식별할 수 있습니다. OpenMP는 Linux, Windows 및 Mac OS X 시스템용 여러 오픈 소스 및 상용 컴파일러에서 사용할 수 있습니다.