// Copyright (C) 2013 Vicente Botet // // 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) #include <boost/config.hpp> #define BOOST_THREAD_VERSION 4 //#define BOOST_THREAD_USES_LOG #define BOOST_THREAD_USES_LOG_THREAD_ID #if ! defined BOOST_NO_CXX11_DECLTYPE #define BOOST_RESULT_OF_USE_DECLTYPE #endif #include <boost/thread/detail/log.hpp> #include <boost/thread/executors/loop_executor.hpp> #include <boost/assert.hpp> #include <boost/thread/thread_only.hpp> #include <string> void p1() { BOOST_THREAD_LOG << boost::this_thread::get_id() << " P1" << BOOST_THREAD_END_LOG; } void p2() { BOOST_THREAD_LOG << boost::this_thread::get_id() << " P2" << BOOST_THREAD_END_LOG; } void submit_some(boost::loop_executor& tp) { tp.submit(&p1); tp.submit(&p2); tp.submit(&p1); tp.submit(&p2); tp.submit(&p1); tp.submit(&p2); tp.submit(&p1); tp.submit(&p2); tp.submit(&p1); tp.submit(&p2); } int main() { BOOST_THREAD_LOG << boost::this_thread::get_id() << " <MAIN" << BOOST_THREAD_END_LOG; { try { boost::loop_executor tp; submit_some(tp); tp.run_queued_closures(); submit_some(tp); tp.run_queued_closures(); } catch (std::exception& ex) { BOOST_THREAD_LOG << "ERRORRRRR " << ex.what() << "" << BOOST_THREAD_END_LOG; return 1; } catch (...) { BOOST_THREAD_LOG << " ERRORRRRR exception thrown" << BOOST_THREAD_END_LOG; return 2; } } BOOST_THREAD_LOG << boost::this_thread::get_id() << "MAIN>" << BOOST_THREAD_END_LOG; return 0; }