【发布时间】:2017-05-19 18:15:23
【问题描述】:
我有一个程序(客户端+服务器)可以正常工作:
boost::asio::write(this->socket_, boost::asio::buffer(message.substr(count,length_to_send)));
其中socket_ 是boost::asio::ssl::stream<boost::asio::ip::tcp::socket>,message 是std::string。
我想让它变得更好和非阻塞,所以我创建了一个可以替换它的函数,它的调用如下:
write_async_sync(socket_,message.substr(count,length_to_send));
这个函数的目的是:
- 本质上使调用异步
- 保持界面不变
我实现的功能只是使用 promise/future 来模拟同步行为,我稍后(在它工作后)将其修改为可取消:
std::size_t
SSLClient::write_async_sync(boost::asio::ssl::stream<boost::asio::ip::tcp::socket>& socket,
const std::string& message_to_send)
{
boost::system::error_code write_error;
std::promise<std::size_t> write_promise;
auto write_future = write_promise.get_future();
boost::asio::async_write(socket,
boost::asio::buffer(message_to_send),
[this,&write_promise,&write_error,&message_to_send]
(const boost::system::error_code& error,
std::size_t size_written)
{
logger.write("HANDLING WRITING");
if(!error)
{
write_error = error;
write_promise.set_value(size_written);
}
else
{
write_promise.set_exception(std::make_exception_ptr(std::runtime_error(error.message())));
}
});
std::size_t size_written = write_future.get();
return size_written;
}
问题:我无法让异步功能正常工作。同步工作正常,但异步只是冻结并且永远不会进入 lambda 部分(写入永远不会发生)。我做错了什么?
编辑:我意识到使用poll_one() 会使函数执行并继续,但我不明白。这就是我为io_service 调用run() 的方式(在启动客户端之前):
io_service_work = std::make_shared<boost::asio::io_service::work>(io_service);
io_service_thread.reset(new std::thread([this](){io_service.run();}));
基本上这些是shared_ptr。这是错的吗?这种方式是否需要使用poll_one()?
【问题讨论】:
-
你有线程,调用 io_service.run() 吗?
-
@florgeng 哦,绝对。通过对
write的同步调用,齿轮工作正常。但是异步是问题所在。io_service被传递给socket_构造。 -
@florgeng 检查我的更新:)
标签: c++ c++11 asynchronous boost boost-asio