您好,欢迎访问一九零五行业门户网

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 系统的多个开源和商业编译器上使用。
以上就是openmp是什么?的详细内容。
其它类似信息

推荐信息