mirror of
https://github.com/boostorg/asio.git
synced 2025-05-12 14:11:39 +00:00
Added new overloads of experimental::make_parallel_group that may be used to launch a dynamically-sized set of asynchronous operations, where all operations are the same type. For example: using op_type = decltype( socket1.async_read_some( boost::asio::buffer(data1), boost::asio::deferred ) ); std::vector<op_type> ops; ops.push_back( socket1.async_read_some( boost::asio::buffer(data1), boost::asio::deferred ) ); ops.push_back( socket2.async_read_some( boost::asio::buffer(data2), boost::asio::deferred ) ); boost::asio::experimental::make_parallel_group(ops).async_wait( boost::asio::experimental::wait_for_all(), []( std::vector<std::size_t> completion_order, std::vector<boost::system::error_code> e, std::vector<std::size_t> n ) { for (std::size_t i = 0; i < completion_order.size(); ++i) { std::size_t idx = completion_order[i]; std::cout << "socket " << idx << " finished: "; std::cout << e[idx] << ", " << n[idx] << "\n"; } } ); Thanks go to Klemens Morgenstern for supplying part of this implementation.