操作系統:Linux 64位ARCH。升壓ASIO異步接受器不開放偵聽端口
BOOST:1.46.1
編譯器:鐺++/GCC。
我有一個代碼片段,具有在boost :: asio示例(Chat Server)上建模的tcp接受器的接線。但是,當我運行該片段時,沒有監聽TCP套接字出現在netstat監聽(linux)中。但是,聊天服務器示例在編譯時顯示出來。有人能指出我做錯了什麼嗎?
#include <boost/asio.hpp>
#include <boost/shared_ptr.hpp>
#include <boost/bind.hpp>
#include <list>
#include <iostream>
using namespace boost::asio;
using namespace boost::asio::ip;
class ClientConnection
{
public:
ClientConnection(io_service & io_s)
: m_socket(io_s) {}
tcp::socket & socket() { return m_socket; }
private:
tcp::socket m_socket;
};
typedef boost::shared_ptr<ClientConnection> client_connection_ptr;
class ClientConnectionAcceptor
{
public:
ClientConnectionAcceptor(unsigned short port)
: m_io_service(),
m_port(port),
m_endpoint(tcp::v4(), m_port),
m_acceptor(m_io_service, m_endpoint)
{
std::cout << "acceptor is open : " << m_acceptor.is_open() << std::endl;
client_connection_ptr ccp(new ClientConnection(m_io_service));
m_acceptor.async_accept(
ccp->socket(),
boost::bind(&ClientConnectionAcceptor::handle_accept,this,
ccp, placeholders::error));
}
void handle_accept(client_connection_ptr ccp, const boost::system::error_code & error)
{
std::cout << "in handle_accept" << std::endl;
if(!error)
{
// m_rpc_oracle.AddNewClient(ccp);
client_connection_ptr new_ccp(new ClientConnection(m_io_service));
m_acceptor.async_accept(
new_ccp->socket(),
boost::bind(&ClientConnectionAcceptor::handle_accept,this,
ccp, placeholders::error));
}
}
io_service & io_service() { return m_io_service; }
private:
boost::asio::io_service m_io_service;
tcp::endpoint m_endpoint;
tcp::acceptor m_acceptor;
unsigned short m_port;
};
int main()
{
ClientConnectionAcceptor acceptor(5000);
acceptor.io_service().run();
}
哇,那確實解決了問題,謝謝。它可能與初始化列表中的初始化順序有關。我認爲這是自上而下的。 –
http://stackoverflow.com/questions/4037219/order-of-execution-in-constructor-initialization-list。用戶「in silico」的迴應,我的假設,那個初始化列表順序決定了評估順序。但是這是決定訂單的聲明順序。我仍然必須嘗試一下。 –
那麼那麼回答你的問題,還是有其他的東西? – aardvarkk