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
를 만나면 시스템에 있는 처리 코어만큼 많은 스레드를 생성합니다. 따라서 듀얼 코어 시스템의 경우 2개의 스레드가 생성되고, 쿼드 코어 시스템의 경우 4개의 스레드가 생성됩니다. 그러면 모든 스레드가 병렬 영역을 동시에 실행합니다. 각 스레드는 병렬 영역을 종료할 때 종료됩니다. OpenMP는 루프 병렬화를 포함하여 코드 영역을 병렬로 실행하기 위한 몇 가지 추가 지시문을 제공합니다.
병렬화 지시문을 제공하는 것 외에도 OpenMP를 사용하면 개발자가 여러 수준의 병렬화 중에서 선택할 수 있습니다. 예를 들어 스레드 수를 수동으로 설정할 수 있습니다. 또한 이를 통해 개발자는 데이터가 스레드 간에 공유되는지 아니면 스레드 전용인지 식별할 수 있습니다. OpenMP는 Linux, Windows 및 Mac OS X 시스템용 여러 오픈 소스 및 상용 컴파일러에서 사용할 수 있습니다.
위 내용은 OpenMP란 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!