then_executor_pass.cpp 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. // Copyright (C) 2014 Vicente Botet
  2. //
  3. // Distributed under the Boost Software License, Version 1.0. (See accompanying
  4. // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  5. // <boost/thread/future.hpp>
  6. // class future<R>
  7. // template<typename F>
  8. // auto then(F&& func) -> future<decltype(func(*this))>;
  9. #define BOOST_THREAD_VERSION 4
  10. #define BOOST_THREAD_PROVIDES_EXECUTORS
  11. //#define BOOST_THREAD_USES_LOG
  12. #define BOOST_THREAD_USES_LOG_THREAD_ID
  13. #include <boost/thread/detail/log.hpp>
  14. #include <boost/thread/future.hpp>
  15. #include <boost/thread/executors/basic_thread_pool.hpp>
  16. #include <boost/thread/executor.hpp>
  17. #include <boost/detail/lightweight_test.hpp>
  18. #if defined BOOST_THREAD_PROVIDES_FUTURE_CONTINUATION
  19. #ifdef BOOST_MSVC
  20. #pragma warning(disable: 4127) // conditional expression is constant
  21. #endif
  22. int p1()
  23. {
  24. BOOST_THREAD_LOG << "p1 < " << BOOST_THREAD_END_LOG;
  25. boost::this_thread::sleep_for(boost::chrono::milliseconds(500));
  26. BOOST_THREAD_LOG << "p1 >" << BOOST_THREAD_END_LOG;
  27. return 1;
  28. }
  29. int p2(boost::shared_future<int> f)
  30. {
  31. BOOST_THREAD_LOG << "p2 <" << &f << BOOST_THREAD_END_LOG;
  32. BOOST_TEST(f.valid());
  33. int i = f.get();
  34. boost::this_thread::sleep_for(boost::chrono::milliseconds(500));
  35. BOOST_THREAD_LOG << "p2 <" << &f << BOOST_THREAD_END_LOG;
  36. return 2 * i;
  37. }
  38. void p3(boost::shared_future<int> f)
  39. {
  40. BOOST_THREAD_LOG << "p3 <" << &f << BOOST_THREAD_END_LOG;
  41. BOOST_TEST(f.valid());
  42. int i = f.get();
  43. boost::this_thread::sleep_for(boost::chrono::milliseconds(500));
  44. BOOST_THREAD_LOG << "p3 <" << &f << " " << i << BOOST_THREAD_END_LOG;
  45. return ;
  46. }
  47. int main()
  48. {
  49. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  50. {
  51. boost::basic_thread_pool ex(1);
  52. boost::shared_future<int> f1 = boost::async(boost::launch::async, &p1).share();
  53. BOOST_TEST(f1.valid());
  54. boost::future<int> f2 = f1.then(ex, &p2);
  55. BOOST_TEST(f2.valid());
  56. try
  57. {
  58. BOOST_TEST(f2.get()==2);
  59. }
  60. catch (std::exception& ex)
  61. {
  62. BOOST_THREAD_LOG << "ERRORRRRR "<<ex.what() << "" << BOOST_THREAD_END_LOG;
  63. BOOST_TEST(false);
  64. }
  65. catch (...)
  66. {
  67. BOOST_THREAD_LOG << " ERRORRRRR exception thrown" << BOOST_THREAD_END_LOG;
  68. BOOST_TEST(false);
  69. }
  70. }
  71. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  72. {
  73. boost::basic_thread_pool ex(1);
  74. boost::shared_future<int> f1 = boost::async(boost::launch::async, &p1).share();
  75. BOOST_TEST(f1.valid());
  76. boost::future<void> f2 = f1.then(ex, &p3);
  77. BOOST_TEST(f2.valid());
  78. try
  79. {
  80. f2.wait();
  81. }
  82. catch (std::exception& ex)
  83. {
  84. BOOST_THREAD_LOG << "ERRORRRRR "<<ex.what() << "" << BOOST_THREAD_END_LOG;
  85. BOOST_TEST(false);
  86. }
  87. catch (...)
  88. {
  89. BOOST_THREAD_LOG << " ERRORRRRR exception thrown" << BOOST_THREAD_END_LOG;
  90. BOOST_TEST(false);
  91. }
  92. }
  93. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  94. {
  95. boost::basic_thread_pool ex(1);
  96. boost::future<int> f2 = boost::async(p1).share().then(ex, &p2);
  97. BOOST_TEST(f2.get()==2);
  98. }
  99. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  100. {
  101. boost::basic_thread_pool ex(1);
  102. boost::shared_future<int> f1 = boost::async(p1).share();
  103. boost::shared_future<int> f21 = f1.then(ex, &p2).share();
  104. boost::future<int> f2= f21.then(ex, &p2);
  105. BOOST_TEST(f2.get()==4);
  106. }
  107. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  108. {
  109. boost::basic_thread_pool ex(1);
  110. boost::shared_future<int> f1 = boost::async(p1).share();
  111. boost::shared_future<int> f21 = f1.then(ex, &p2).share();
  112. boost::future<int> f2= f21.then(&p2);
  113. BOOST_TEST(f2.get()==4);
  114. }
  115. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  116. {
  117. boost::basic_thread_pool ex(1);
  118. boost::shared_future<int> f1 = boost::async(p1).share();
  119. boost::future<int> f2= f1.then(ex, &p2).share().then(ex, &p2);
  120. BOOST_TEST(f2.get()==4);
  121. }
  122. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  123. {
  124. boost::basic_thread_pool ex(1);
  125. boost::future<int> f2 = boost::async(p1).share().then(ex, &p2).share().then(ex, &p2);
  126. BOOST_TEST(f2.get()==4);
  127. }
  128. return boost::report_errors();
  129. }
  130. #else
  131. int main()
  132. {
  133. return 0;
  134. }
  135. #endif