vibe.d beta banner
get vibe.d
0.10.1

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

Function runWorkerTaskDist

Runs a new asynchronous task in all worker threads concurrently.

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

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

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

void runWorkerTaskDist(alias method, T, ARGS...) (
  TaskSettings settings,
  shared(T) object,
  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 workerThreadCount.

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.