重新构造Boost ASIO TCP服务器类,以便对会话实例进行公共访问

重新构造Boost ASIO TCP服务器类,以便对会话实例进行公共访问,boost,tcp,boost-asio,Boost,Tcp,Boost Asio,我正在使用Boost ASIO TCP示例,对会话实例(新会话)的访问有疑问。基本上,我希望能够统计活动会话实例,并在每个会话的handle_write方法中写入不同的数据集。重构服务器类以访问服务器类之外的会话实例的最佳方法是什么 class session { public: session(boost::asio::io_service& io_service) : socket_(io_service) { } tcp::soc

我正在使用Boost ASIO TCP示例,对会话实例(新会话)的访问有疑问。基本上,我希望能够统计活动会话实例,并在每个会话的handle_write方法中写入不同的数据集。重构服务器类以访问服务器类之外的会话实例的最佳方法是什么

class session
{
public:
    session(boost::asio::io_service& io_service) 
        : socket_(io_service)
    {
    }

    tcp::socket& socket()
    {
        return socket_;
    }

    void start()
    {
    std::string message("First message from server\n");
    boost::asio::write(socket, boost::asio::buffer(message));
    }

    void handle_write(const boost::system::error_code& error)
    {
        if (!error)
        {
            std::string message("Hello from server\n");
        boost::asio::write(socket, boost::asio::buffer(message));
        }
        else
        {
        delete this;
        }
    }

private:
    tcp::socket socket_;
    enum { max_length = 1024 };
    char data_[max_length];
};


class server
{
public:
    server(boost::asio::io_service& io_service, short port)
        : io_service_(io_service),
            acceptor_(io_service, tcp::endpoint(tcp::v4(), port))
    {
        session* new_session = new session(io_service_);
        acceptor_.async_accept(new_session->socket(),
        boost::bind(&server::handle_accept, this, new_session,
            boost::asio::placeholders::error));
    }

    void handle_accept(session* new_session,
        const boost::system::error_code& error)
    {
        if (!error)
        {
            new_session->start();
            new_session = new session(io_service_);
            acceptor_.async_accept(new_session->socket(),
            boost::bind(&server::handle_accept, this, new_session,
            boost::asio::placeholders::error));
        }
        else
        {
            delete new_session;
        }
    }

private:
    boost::asio::io_service& io_service_;
    tcp::acceptor acceptor_;
};

为了尝试在handle_write方法中写入不同的数据集,我创建了一个线程安全的数据报队列,在handle_write方法中从队列中弹出一个数据报。这似乎适用于单个连接的客户端,但不适用于多个客户端,因为队列不是每个新的_会话所独有的,而是我需要作为全局队列与之交互的代码集的一部分。数据报从工作线程推送到队列上。这让我想知道如何重新构造server类以访问会话实例,从而在server类之外运行。我遇到的问题是,如果两个客户端连接到TCP服务器,然后,每个客户端以交替方式从队列中弹出一个数据报,以便第一个客户端弹出奇数个数据报包,第二个客户端弹出偶数个数据报包。因此,我认为我需要一种机制来迭代活动会话以写入所有连接的客户机,以便每个客户机接收从队列中弹出的所有数据报数据包。这让我想问,如何重组服务器类以访问会话实例,从而在服务器类之外运行。我的意思是,为了重组该类,您尝试了哪些方法,以及在重组过程中遇到了哪些问题。您可以在
服务器中管理vector
并以某种方式公开它。谢谢Igor,您的建议对我来说是一个解决方案。