d并行两个循环

Posted fqbqrr

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了d并行两个循环相关的知识,希望对你有一定的参考价值。


​原文​

import std.stdio;
import std.parallelism;
import std.conv;

enum I = 1_000;
enum J = 1_000;

void main()
auto results = new int[I * J];

//如果想要新的任务池:
// auto tp = new TaskPool(totalCPUs);
//(并在下面使用tp.而不是taskPool.)
foreach (i; 0 .. I)
foreach (j; 0 .. J)
taskPool.put(task!foo(i, j, results));



//警告:我不确定是否可以相信结果是否准备好.(?)
//parallel()确实在每个任务上调用了yieldForce(),但对`put`进池中的任务,似乎没有该选项.

enum toPrint = 10;
writeln(results[0..toPrint]);
writeln("[...]");
writeln(results[$-toPrint..$]);


void foo(size_t i, size_t j, int[] results)
results[i * J + j] = to!int(i * J + j);


以上是关于d并行两个循环的主要内容,如果未能解决你的问题,请参考以下文章

用两条语句并行化 while 循环(弗洛伊德循环检测算法)

并行执行 n 次 for 循环迭代

CUDA:并行化具有嵌套循环的函数调用的多个嵌套for循环

在 Python 中并行化四个嵌套循环

是否可以在同一存储过程中并行处理for循环?

带有 break openmp 的并行 If-else 循环