Во время чтения документации coroutine2
Я нашел хороший отрывок кода, который показывает, как использовать его с asio
Для справки вот код из документации:
void session(boost::asio::io_service& io_service){
// construct TCP-socket from io_service
boost::asio::ip::tcp::socket socket(io_service);
try{
for(;;){
// local data-buffer
char data[max_length];
boost::system::error_code ec;
// read asynchronous data from socket
// execution context will be suspended until
// some bytes are read from socket
std::size_t length=socket.async_read_some(
boost::asio::buffer(data),
boost::asio::yield[ec]);
if (ec==boost::asio::error::eof)
break; //connection closed cleanly by peer
else if(ec)
throw boost::system::system_error(ec); //some other error
// write some bytes asynchronously
boost::asio::async_write(
socket,
boost::asio::buffer(data,length),
boost::asio::yield[ec]);
if (ec==boost::asio::error::eof)
break; //connection closed cleanly by peer
else if(ec)
throw boost::system::system_error(ec); //some other error
}
} catch(std::exception const& e){
std::cerr<<"Exception: "<<e.what()<<"\n";
}
}
Однако я не могу найти рабочий пример в документации asio, и попытка скомпилировать этот фрагмент на coliru дает мне ошибки компилятора, связанные с yield
Знаете ли вы о минимальной клиент-серверной реализации, которая использует coroutine2
как показано в примере выше?
AFAIK boost.asio поддерживает только boost.coroutine, но не boost.coroutine2
Приведен пример сервера на основе Boost.Asio с использованием сопрограмм. Вот.
В примере, показанном в документации Boost.Coroutine, отсутствует та часть, где boost::asio::spawn
используется для создания yield_context
это может быть передано как асинхронный обработчик.
Следуя #include
цепь внутри <boost/asio/spawn.hpp>
, кажется, включает только Boost.Coroutine v1.