Sha256: 9d11820ab27f8cc2eb0c6d633a2f6d1f1ae325c3e831cd206dde503e8cacdeea
Contents?: true
Size: 1.59 KB
Versions: 12
Compression:
Stored size: 1.59 KB
Contents
// // impl/thread_pool.ipp // ~~~~~~~~~~~~~~~~~~~~ // // Copyright (c) 2003-2018 Christopher M. Kohlhoff (chris at kohlhoff dot com) // // Distributed under the Boost Software License, Version 1.0. (See accompanying // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) // #ifndef BOOST_ASIO_IMPL_THREAD_POOL_IPP #define BOOST_ASIO_IMPL_THREAD_POOL_IPP #if defined(_MSC_VER) && (_MSC_VER >= 1200) # pragma once #endif // defined(_MSC_VER) && (_MSC_VER >= 1200) #include <boost/asio/detail/config.hpp> #include <boost/asio/thread_pool.hpp> #include <boost/asio/detail/push_options.hpp> namespace boost { namespace asio { struct thread_pool::thread_function { detail::scheduler* scheduler_; void operator()() { boost::system::error_code ec; scheduler_->run(ec); } }; thread_pool::thread_pool() : scheduler_(use_service<detail::scheduler>(*this)) { scheduler_.work_started(); thread_function f = { &scheduler_ }; std::size_t num_threads = detail::thread::hardware_concurrency() * 2; threads_.create_threads(f, num_threads ? num_threads : 2); } thread_pool::thread_pool(std::size_t num_threads) : scheduler_(use_service<detail::scheduler>(*this)) { scheduler_.work_started(); thread_function f = { &scheduler_ }; threads_.create_threads(f, num_threads); } thread_pool::~thread_pool() { stop(); join(); } void thread_pool::stop() { scheduler_.stop(); } void thread_pool::join() { scheduler_.work_finished(); threads_.join(); } } // namespace asio } // namespace boost #include <boost/asio/detail/pop_options.hpp> #endif // BOOST_ASIO_IMPL_THREAD_POOL_IPP
Version data entries
12 entries across 12 versions & 1 rubygems