Skip to content
Snippets Groups Projects
Select Git revision
  • 48ea2b1730c64271405cd5d00aa916ea2c2edacb
  • master default protected
  • release/202005
  • release/202001
  • release/201912
  • release/201911
  • release/releaseWindowsTestOne
  • release/windowsReleaseTest
  • release/releaseTest
  • release/releaseWindowsTest
  • release/201910
  • release/qt/201910
  • release/windows-test/201910
  • release/201908
  • release/201906
  • release/201905
  • release/201904
  • release/201903
  • release/201902
  • release/201901
  • release/201812
  • 4.0.0
  • 2.2.0
  • 2.1.0
  • 2.0.1
  • 2.0.0
  • 1.4.1
  • 1.4.0
  • 1.3.0
  • 1.2.0
  • 1.1.0
31 results

thread_pool.h

  • Code owners
    Assign users and groups as approvers for specific file changes. Learn more.
    thread_pool.h 1.84 KiB
    /*
     *  Copyright (C) 2016-2017 Savoir-faire Linux Inc.
     *
     *  Author: Adrien Béraud <adrien.beraud@savoirfairelinux.com>
     *
     *  This program is free software; you can redistribute it and/or modify
     *  it under the terms of the GNU General Public License as published by
     *  the Free Software Foundation; either version 3 of the License, or
     *  (at your option) any later version.
     *
     *  This program is distributed in the hope that it will be useful,
     *  but WITHOUT ANY WARRANTY; without even the implied warranty of
     *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     *  GNU General Public License for more details.
     *
     *  You should have received a copy of the GNU General Public License
     *  along with this program. If not, see <http://www.gnu.org/licenses/>.
     */
    
    #pragma once
    
    #include <condition_variable>
    #include <vector>
    #include <queue>
    #include <future>
    #include <functional>
    
    namespace ring {
    
    class ThreadPool {
    public:
        static ThreadPool& instance() {
            static ThreadPool pool;
            return pool;
        }
    
        ThreadPool();
        ~ThreadPool();
    
        void run(std::function<void()>&& cb);
    
        template<class T>
        std::future<T> get(std::function<T()>&& cb) {
            auto ret = std::make_shared<std::promise<T>>();
            run(std::bind([=](std::function<T()>& mcb) mutable {
                    ret->set_value(mcb());
                }, std::move(cb)));
            return ret->get_future();
        }
        template<class T>
        std::shared_ptr<std::future<T>> getShared(std::function<T()>&& cb) {
            return std::make_shared<std::future<T>>(get(std::move(cb)));
        }
    
        void join();
    
    private:
        struct ThreadState;
        std::queue<std::function<void()>> tasks_ {};
        std::vector<std::unique_ptr<ThreadState>> threads_;
        unsigned readyThreads_ {0};
        std::mutex lock_ {};
        std::condition_variable cv_ {};
    
        const unsigned maxThreads_;
    };
    
    }