A fast, almost lock-free, cross-platform, full CPU utilizing thread pool implementation using C++11 features.
You can find the dead simple API documentation on header comments.
This project was initially developed in just a few hours of free time as I could not find a simple lightweight thread pooling library for my needs.
Here is a result of OpenMP demo found in the tree.
Your machine's hardware concurrency is 8
threadpool11 execution took 22704 milliseconds.
threadpool11 (no future) execution took 21198 milliseconds.
openmp execution took 21663 milliseconds.
openmp execution (dynamic schedule) took 21335 milliseconds.
gcc -v gcc version 8.2.1 20181127 (GCC)
Testing code can be found in project tree.
I will be glad to hear about the suggestions/ideas you have about the project, via the issue reporting section.
All non '-dev' branches are safe to use but prefer the latest version.
% mkdir -p build
% cd build
% cmake ..
% make
% make test
% make install
% mkdir -p build
% cd build
% cmake -DBUILD_SHARED_LIBS:BOOL=ON ..
% make
% make test
% make install