该代码安全吗?
class C : public std::enable_shared_from_this<C> {
void start() {
boost::asio::async_write(socket_, boost::asio::buffer(message_),
std::bind(&tcp_connection::handle_write, shared_from_this(),
_1, _2));
};
// ...
};
class D {
void start()
{
std::shared_ptr<C> cptr = std::make_shared<C>(); // (1)
cptr->start();
} // (2)
};
如果消息很长,async_write
操作可能需要很长时间。
在点(1)处只有一个shared_ptr
指向C
对象。 start()
被调用,start()
结束,在(2)变量cptr
超出范围并被销毁。
当async_write
完成写操作时,调用回调;这会导致崩溃,因为shared_from_this()
会尝试向不存在的对象生成shared_ptr
。
对这种情况的描述是否正确?
答案 0 :(得分:7)
不,你不对。
shared_from_this()
的调用发生在start
返回之前。结果shared_ptr
的副本由bind
的结果保存。
所以当你到达(2)时,对象的两个引用中只有一个已经消失,并且它仍然存在