mirror of
https://github.com/boostorg/asio.git
synced 2026-01-28 06:42:08 +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.
71 lines
1.8 KiB
C++
71 lines
1.8 KiB
C++
//
|
|
// ranged_wait_for_all.cpp
|
|
// ~~~~~~~~~~~~~~~~~~~~~~~
|
|
//
|
|
// Copyright (c) 2003-2022 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)
|
|
//
|
|
|
|
#include <boost/asio.hpp>
|
|
#include <boost/asio/experimental/parallel_group.hpp>
|
|
#include <iostream>
|
|
#include <vector>
|
|
|
|
#ifdef BOOST_ASIO_HAS_POSIX_STREAM_DESCRIPTOR
|
|
|
|
int main()
|
|
{
|
|
boost::asio::io_context ctx;
|
|
|
|
boost::asio::posix::stream_descriptor out(ctx, ::dup(STDOUT_FILENO));
|
|
boost::asio::posix::stream_descriptor err(ctx, ::dup(STDERR_FILENO));
|
|
|
|
using op_type = decltype(
|
|
out.async_write_some(
|
|
boost::asio::buffer("", 0),
|
|
boost::asio::deferred
|
|
)
|
|
);
|
|
|
|
std::vector<op_type> ops;
|
|
|
|
ops.push_back(
|
|
out.async_write_some(
|
|
boost::asio::buffer("first\r\n", 7),
|
|
boost::asio::deferred
|
|
)
|
|
);
|
|
|
|
ops.push_back(
|
|
err.async_write_some(
|
|
boost::asio::buffer("second\r\n", 8),
|
|
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> ec,
|
|
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 << "operation " << idx << " finished: ";
|
|
std::cout << ec[idx] << ", " << n[idx] << "\n";
|
|
}
|
|
}
|
|
);
|
|
|
|
ctx.run();
|
|
}
|
|
|
|
#else // defined(BOOST_ASIO_HAS_POSIX_STREAM_DESCRIPTOR)
|
|
int main() {}
|
|
#endif // defined(BOOST_ASIO_HAS_POSIX_STREAM_DESCRIPTOR)
|