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系统的几种开源和商业编译器上可用。