#pragma omp parallel for是OpenMP中的一個指令,表示接下來的for循環將被多線程執行,另外每次循環之間不能有關系。示例如下:
int main(int argc, char* argv[])
{
#pragma omp parallel for //后面是for循環
for (int i = 0; i < 10; i++ )
{
printf("i = %d/n", i);
}
return 0;
}
這個程序執行后打印出以下結果:
i = 0
i = 5
i = 1
i = 6
i = 2
i = 7
i = 3
i = 8
i = 4
i = 9
for循環里的內容必須滿足可以並行執行,即每次循環互不相干,后一次循環不依賴於前面的循環。
