我正在查看boost::asio 教程的一页。
class tcp_server
{
public:
tcp_server(boost::asio::io_service& io_service)
: acceptor_(io_service, tcp::endpoint(tcp::v4(), 13))
{
start_accept();
}
private:
void start_accept()
{
tcp_connection::pointer new_connection =
tcp_connection::create(acceptor_.get_io_service()); // shared_ptr got created.
acceptor_.async_accept(new_connection->socket(),
boost::bind(&tcp_server::handle_accept, this, new_connection,
boost::asio::placeholders::error)); // instance added to io_service task list, but bind does not use shared_ptr internally I believe.
} // shared_ptr of tcp_connection goes out of scope.
void handle_accept(tcp_connection::pointer new_connection,
const boost::system::error_code& error)
{
if (!error)
{
new_connection->start();
}
start_accept();
}
class tcp_connection
: public boost::enable_shared_from_this<tcp_connection>
{
public:
typedef boost::shared_ptr<tcp_connection> pointer;
static pointer create(boost::asio::io_service& io_service)
{
return pointer(new tcp_connection(io_service));
}
tcp::socket& socket()
{
return socket_;
}
void start()
{
message_ = make_daytime_string();
boost::asio::async_write(socket_, boost::asio::buffer(message_),
boost::bind(&tcp_connection::handle_write, shared_from_this(),
boost::asio::placeholders::error,
boost::asio::placeholders::bytes_transferred));
}
private:
tcp_connection(boost::asio::io_service& io_service)
: socket_(io_service)
{
}
void handle_write(const boost::system::error_code& /*error*/,
size_t /*bytes_transferred*/)
{
}
tcp::socket socket_;
std::string message_;
};
我发现有一部分运行时间没有shared_ptr
对象的tcp_connection
对象是活着的。这似乎意味着该tcp_connection
对象将在该部分的开头被销毁,因为它的计数shared_ptr
下降到零,这显然不是我们想要的。
但是后来我看到了课堂tcp_connection
引用中的评论
我们将使用 shared_ptr 和 enable_shared_from_this 因为我们希望 tcp_connection 对象只要有引用它的操作就保持活动状态。
我也搜索了这个问题,并在 SO here中得到了一个问答。但是我仍然对标题问题感到困惑。具体是什么意思there is an operation that refers to it
?在tcp_server::start_accept()
返回时,所有实例shared_ptr
都tcp_connection
应该超出范围,并且可能只有一些原始指针引用被添加到io_service
任务列表中。当没有该对象的实例时,如何enabled_shared_from_this
防止堆实例被破坏?或者它与 enabled_shared_from_this 无关,而是内部有界 async_handler的保持?tcp_connection
shared_ptr
tcp_connection
boost::asio::io_service
shared_ptr