首页 > 文章列表 > OpenMP是什么?

OpenMP是什么?

多线程 并行编程 任务分配
455 2023-09-07

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 系统的多个开源和商业编译器上使用。