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);
}
posted @   zjh6  阅读(11)  评论(0编辑  收藏  举报  
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示