// Copyright (C) 2012-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 #if ! defined BOOST_NO_CXX11_DECLTYPE #define BOOST_RESULT_OF_USE_DECLTYPE #endif #define BOOST_THREAD_VERSION 4 //#define BOOST_THREAD_USES_LOG #define BOOST_THREAD_USES_LOG_THREAD_ID #include #include #include #include #include #if defined BOOST_THREAD_PROVIDES_FUTURE_UNWRAP #ifdef BOOST_MSVC #pragma warning(disable: 4127) // conditional expression is constant #endif int p1() { BOOST_THREAD_LOG << "P1" << BOOST_THREAD_END_LOG; return 123; } boost::future p2() { BOOST_THREAD_LOG << " f1 = boost::async(boost::launch::async, &p1); BOOST_THREAD_LOG << "P2>" << BOOST_THREAD_END_LOG; return boost::move(f1); } int main() { const int number_of_tests = 100; BOOST_THREAD_LOG << " inner_future = boost::async(boost::launch::async, &p2).unwrap(); inner_future.wait(); int ii = inner_future.get(); BOOST_THREAD_LOG << "ii= "<< ii << "" << BOOST_THREAD_END_LOG; } #endif { boost::future > outer_future = boost::async(boost::launch::async, &p2); boost::future inner_future = outer_future.unwrap(); inner_future.wait(); int ii = inner_future.get(); BOOST_THREAD_LOG << "ii= "<< ii << "" << BOOST_THREAD_END_LOG; } { boost::future > outer_future = boost::async(boost::launch::async, &p2); boost::future inner_future = outer_future.unwrap(); int ii = inner_future.get(); BOOST_THREAD_LOG << "ii= "<< ii << "" << BOOST_THREAD_END_LOG; } } catch (std::exception& ex) { std::cout << "ERRORRRRR "<" << BOOST_THREAD_END_LOG; return 0; } #else int main() { return 0; } #endif