【发布时间】:2013-10-16 02:51:41
【问题描述】:
我在看一个page 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 任务列表中。当这个tcp_connection 对象没有shared_ptr 的实例时,enabled_shared_from_this 如何防止tcp_connection 的堆实例被销毁?或者它与enabled_shared_from_this无关,但boost::asio::io_service在内部保留有界async_handler的shared_ptr?
【问题讨论】:
标签: c++11 shared-ptr