【发布时间】:2015-02-26 04:14:30
【问题描述】:
我正在尝试在 asio 中保留已连接客户端的列表。我改编了文档 (http://www.boost.org/doc/libs/1_57_0/doc/html/boost_asio/example/cpp03/chat/chat_server.cpp) 中的聊天服务器示例,这是我最终得到的重要部分:
#include <iostream>
#include <boost/bind.hpp>
#include <boost/shared_ptr.hpp>
#include <boost/enable_shared_from_this.hpp>
#include <boost/asio.hpp>
#include <set>
using boost::asio::ip::tcp;
class tcp_connection;
std::set<boost::shared_ptr<tcp_connection>> clients;
void add_client(boost::shared_ptr<tcp_connection> client)
{
clients.insert(client);
}
class tcp_connection : public boost::enable_shared_from_this<tcp_connection>
{
public:
tcp_connection(boost::asio::io_service& io_service) : socket_(io_service)
{
}
tcp::socket socket_;
void start()
{
add_client(shared_from_this());
}
tcp::socket& socket()
{
return socket_;
}
};
class tcp_server
{
public:
tcp_server(boost::asio::io_service& io_service)
: io_service_(io_service),
acceptor_(io_service, tcp::endpoint(tcp::v4(), 6767))
{
tcp_connection* new_connection = new tcp_connection(io_service_);
acceptor_.async_accept(new_connection->socket(),
boost::bind(&tcp_server::start_accept, this, new_connection,
boost::asio::placeholders::error));
}
private:
void start_accept(tcp_connection* new_connection,
const boost::system::error_code& error)
{
if (!error)
{
new_connection->start();
new_connection = new tcp_connection(io_service_);
acceptor_.async_accept(new_connection->socket(),
boost::bind(&tcp_server::start_accept, this, new_connection,
boost::asio::placeholders::error));
}
}
boost::asio::io_service& io_service_;
tcp::acceptor acceptor_;
};
int main()
{
try
{
boost::asio::io_service io_service;
tcp_server server(io_service);
io_service.run();
}
catch (std::exception& e)
{
std::cerr << "Exception: " << e.what() << "\n";
}
return 0;
}
在调用shared_from_this() 时,我的服务器崩溃并显示以下消息:
例外:tr1::bad_weak_ptr
我进行了一些搜索,似乎 shared_from_this() 非常特别,但我似乎无法准确找到我需要更改的内容。
【问题讨论】:
-
为什么将
new的结果存储在一个原始指针中,以便以后使用shared_from_this()?看来您的设计可以简化以完全消除这个问题。 -
enable_shared_from_this的 boost 文档说There must exist at least one shared_ptr instance p that owns t,你似乎没有。 -
@JonathanPotter 我读过,但我不明白。
-
@chrisvj 我的解释是你需要已经有一个
shared_ptr来保存对象,然后才能使用shared_from_this进行更多操作。虽然我自己从未使用过,所以这只是一个猜测。 -
只有在生命周期由共享指针管理的对象上调用
shared_from_this才有意义。否则,不可能有一个共享指针的生命周期至少与对象的生命周期一样长,而shared_from_this的唯一目的就是返回这样的东西。所以,总而言之,你是在要求shared_from_this做不可能的事情。
标签: c++ boost shared-ptr c++-faq