Computer >> 컴퓨터 >  >> 프로그램 작성 >> C 프로그래밍

OpenMP란 무엇입니까?

<시간/>

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 시스템용 여러 오픈 소스 및 상용 컴파일러에서 사용할 수 있습니다.