Boost.Asio,同一个套接字的两个读数

时间:2015-05-16 17:06:15

标签: c++ sockets boost boost-asio

我正在学习Boost.Asio。我已经定义了一个具有客户端和服务器角色的类:

  • 我可以创建连接,发送请求和接收响应(客户端角色)。
  • 我可以接受请求并发送对这些请求的响应(服务器角色)。
  • 我还可以创建订阅:创建连接,它发送订阅请求并等待响应。如果远程端点接受请求,它将通过此​​连接定期向我发送数据。

我希望能够在订阅后发出请求并收到响应,但是当我收到响应时出现问题:此时同时等待的套接字会收到订阅和响应。

有时会出现死锁,有时我会在等待回复时收到订阅,...

要阅读,我使用以下功能:

void async_receive_subscription(const socket& the_socket, read_handler_signature handler)
{
    auto self( this->shared_from_this() );

    boost::asio::async_read(
        the_socket.get(),
        boost::asio::buffer( my_buffer ),
        [this, self, the_socket, my_buffer, handler]
        ( const boost::system::error_code& error,
          std::size_t bytes_transferred )
        {
            the_socket.get().get_io_service().post(
                std::bind(
                handler,
                error,
                bytes_transferred,
                the_socket,
                my_buffer
                )
            );
            // Read the next subscription.
            async_receive_subscription(the_socket, handler);
        }
    );
}

void async_receive(const socket& the_socket, read_handler_signature handler)
{
    auto self( this->shared_from_this() );

    boost::asio::async_read(
        the_socket.get(),
        boost::asio::buffer( my_buffer ),
        [this, self, the_socket, my_buffer, handler]
        ( const boost::system::error_code& error,
          std::size_t bytes_transferred )
        {
            the_socket.get().get_io_service().post(
                std::bind(
                handler,
                error,
                bytes_transferred,
                the_socket,
                my_buffer
                )
            );
        }
    );
}

是否有可能期望同一个套接字有两个响应?是否有可用于避免此问题的同步机制?

感谢。

1 个答案:

答案 0 :(得分:2)

async_read保证只引起一次处理程序调用。

在调用此处理程序之前,不得再次调用async_read。

问题:

  1. 你是在多个线程中运行io_service吗?如果是这样,您需要通过asio :: strand传递处理程序。