我正在查看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_connectionshared_ptrtcp_connectionboost::asio::io_serviceshared_ptr