Artifact 5655f25b59cc69ba4857e6de38f0fbd77ad2b36ca82311254dd527f12cbcf9ef:
- File par/1-spinner/spinner.d — part of check-in [40a2744c9d] at 2021-10-30 19:24:22 on branch trunk — add 'spinner' example from Go Programming Language ch8 golang works 2.18x as hard (perf stat cycle count) to take 2.31x times as long (hyperfine runtime) as spinner.gdc. (user: admin size: 586)
import std.stdio;
import std.concurrency;
import core.thread;
void main() {
spawnLinked(&spinner, 100.msecs);
enum n = 45;
auto fibN = fib(n); // slow
writefln!"\rFibonacci(%d) = %d"(n, fibN);
}
void spinner(const Duration delay) {
while (true) {
bool done;
foreach (r; `-\|/`) {
writef!"\r%c"(r);
stdout.flush;
receiveTimeout(delay, (OwnerTerminated msg) { done = true; });
if (done)
return;
}
}
}
int fib(int x) pure {
return x < 2 ? x : fib(x - 1) + fib(x - 2);
}