D并行与旋转器

原文

import std.stdio;
import std.concurrency;
import core.thread;

void main() {
  spawnLinked(&spinner, 100.msecs);
  enum n = 45;
  const fibN = fib(n); // slow
  writefln!"\rFibonacci(%d) = %d"(n, fibN);
}

void spinner(const(Duration) delay) {
  for (;;) {
    foreach (r; `-\|/`) {
      writef!"\r%c"(r);
      stdout.flush();
      bool done;
      receiveTimeout(delay,
                     (OwnerTerminated msg) {
                       done = true;
                     });
      if (done) {
        return;
      }
    }
  }
}

auto fib(int x) {
  if (x < 2) {
    return x;
  }
  return fib(x-1) + fib(x-2);
}

D并行Fib.检查返回值:

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