vibe.d beta banner
get vibe.d
0.10.0

Asynchronous I/O that doesn’t get in your way, written in D

Function TaskPool.runTaskDist

Runs a new asynchronous task in all worker threads concurrently.

void runTaskDist(FT, ARGS...) (
  FT func,
  auto ref ARGS args
)
if (isFunctionPointer!FT && isNothrowCallable!(FT, ARGS));

void runTaskDist(alias method, T, ARGS...) (
  shared(T) object,
  auto ref ARGS args
)
if (isNothrowMethod!(shared(T), method, ARGS));

void runTaskDist(FT, ARGS...) (
  TaskSettings settings,
  FT func,
  auto ref ARGS args
)
if (isFunctionPointer!FT && isNothrowCallable!(FT, ARGS));

void runTaskDist(alias method, T, ARGS...) (
  TaskSettings settings,
  shared(T) object,
  auto ref ARGS args
)
if (isNothrowMethod!(shared(T), method, ARGS));

This function is mainly useful for long-living tasks that distribute their work across all CPU cores. Only function pointers with weakly isolated arguments are allowed to be able to guarantee thread-safety.

The number of tasks started is guaranteed to be equal to threadCount.

Authors

Sönke Ludwig

Copyright

© 2012-2020 Sönke Ludwig

License

Subject to the terms of the MIT license, as written in the included LICENSE.txt file.