- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在编写一个使用 boost asio 连接到远程套接字的小型客户端类。如果初始连接失败,它应该能够尝试重新连接。
在测试该场景时,即没有打开的远程套接字,第一次正确调用了 async_connect 的完成处理程序。但是当 m_state 再次进入 State_Connect 时,我的完成处理程序将永远不会再次调用第二次尝试。我做错了什么?
class Test
{
public:
Test() : m_socket(m_io)
{
}
void update()
{
switch (m_state)
{
case State_Connect:
std::cout << "Start connect\n";
m_socket.async_connect(tcp::endpoint(tcp::v4(), 33000),
boost::bind(&Test::onCompleted, this, asio::placeholders::error));
m_state = State_Connecting;
break;
case State_Connecting:
if (m_error)
{
m_error.clear();
std::cout << "Could not connect\n";
m_state = State_Connect;
}
break;
}
m_io.poll_one();
}
private:
void onCompleted(const bs::error_code& error)
{
if (error)
{
m_error = error;
m_socket.close();
}
}
enum State
{
State_Connect,
State_Connecting,
};
State m_state = State_Connect;
asio::io_service m_io;
tcp::socket m_socket;
bs::error_code m_error;
};
int main(int argc, char* argv[])
{
Test test;
for (;;)
{
test.update();
boost::this_thread::sleep(boost::posix_time::milliseconds(20));
}
return 0;
}
输出是: 开始连接 无法连接 开始连接
但我希望它会无限期地重复。
最佳答案
When an io_context object is stopped, calls to run(), run_one(), poll() or poll_one() will return immediately without invoking any handlers.
当您调用 poll_one()
并且没有处理程序准备就绪时,poll_one()
函数会将 io_service
标记为已停止。当 m_state
为 State_Connecting
时,poll_one()
无关,此时 io_service 由于处理程序队列为空而被标记为已停止。
你可以测试io_service
是否停止了,如果是则调用reset
:
if (m_io.stopped())
m_io.reset();
m_io.poll_one();
关于c++ - async_connect 上的 boost::asio 完成处理程序在第一次失败后不再调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54095005/
我正在尝试检查 boost::asio::async_connect 是否成功,但我没有收到错误,即使服务器未启动。如何正确检查是否成功?谢谢! main.cpp #include #include
我正在尝试为我的项目从 boost TCP 客户端示例创建一个客户端类,并且我注意到有时在连接到不存在的主机时不会调用 handle_connect。 我在堆栈上读过类似的问题,人们忘记运行 io_s
短篇小说:socket.async_connect(...) 之后的调用 socket.cancel() 完美运行,即调用了完成处理程序;但是对于 asio::async_connect(socket
我想知道传递给上述方法的对象的生命周期是多少。 异步解析 ip::basic_resolver::async_resolve(const query & q, ResolveHandler handl
我在修改 asio 的阻塞套接字时没有遇到任何问题,但我对异步套接字的深入研究一直是一场噩梦。也许我只是累坏了: using boost::asio::ip::tcp; boost::asio
我偶尔会遇到这个问题。我们有一个使用 boost::asio 和 deadline_timer 实现的 http 客户端来处理连接/请求超时。 async_connect 被调用。 deadline_
我正在编写一个使用 boost asio 连接到远程套接字的小型客户端类。如果初始连接失败,它应该能够尝试重新连接。 在测试该场景时,即没有打开的远程套接字,第一次正确调用了 async_connec
我正在使用 asio 构建一个可以通过 TCP 或 unix 套接字连接到远程系统的网络库。我使用 asio::generic::stream_protocol::socket,它同时具有 conne
我正在尝试实现带有超时的 async_connect()。 async_connect_with_timeout(socket_type & s, std::function
我想检查 Boost Asio 是否真的执行异步连接。根据the diagrams corresponding to the asynchronous calls发表在Asio的基础知识中,当io_s
我有一个服务器应用程序,其中我只接受一个带有 boost::asio::ip::tcp::acceptor 和 async_accept 的客户端。 我运行客户端应用程序并使用 boost::asio
我已经关注了 documentation and examples由 boost asio 实现提供,但在将我的客户端连接到服务器后没有任何运气。无论成功还是失败,处理程序都不会被调用。我已验证服务器
我正在学习使用 Boost ASIO。这是我的代码改编自 Boost 文档的 chat example . class AsioCommunicationService { AsioCommunica
我成功地实现了 async_connect,使用它作为一个自由函数和一个 lambda 作为 connect_handler,如下所示: auto self(shared_from_this());
我刚刚通过 TCPView 发现使用 boost::asio 建立的一个 TCP 连接创建了两个连接。其中之一使用本地端口,第二个使用所需的远程端口。为什么?这种行为正常吗?有没有办法只创建一个? 这
我正在尝试运行以下代码: some_sock.async_connect(...); // handle_connect() sets the 'condition' flag boost::asio
我是一名优秀的程序员,十分优秀!