bad_weak_ptr при использовании наследования классов от boost :: asio :: io_context :: service

Я начал практиковать, используя Boost Asio & Boost Beast, чтобы разработать свой собственный базовый сервер и класс соединения. Недавно я столкнулся с исключением bad_weak_ptr и не могу понять, как решить проблему. Вот код:

class server : public boost::asio::io_context::service
{
tcp::endpoint endpoint{ boost::asio::ip::address_v6::any(), 7654 };
tcp::acceptor acceptor;
boost::asio::strand<boost::asio::io_context::executor_type> strand;
std::vector<std::weak_ptr<tcp_connection_ui>> connections;
public:
static const boost::asio::execution_context::id id;

explicit tcp_server_ui(boost::asio::io_context& ioc)
: boost::asio::io_context::service{ ioc }
, acceptor{ ioc, endpoint }
, strand{ ioc.get_executor() }
{
}

void run()
{
boost::asio::post(strand, [this] {start_accept(); });
}

void start_accept()
{
tcp::socket socket{ acceptor.get_io_context() };
tcp_connection_ui::pointer new_connection =
tcp_connection_ui::create(std::move(socket));

connections.push_back(new_connection);

acceptor.async_accept(new_connection->web_socket().next_layer(),
boost::asio::bind_executor(strand, std::bind(
&tcp_server_ui::handle_accept,
this, new_connection, std::placeholders::_1)));
}

void handle_accept(tcp_connection_ui::pointer new_connection,
boost::system::error_code ec)
{
if (!ec) {
new_connection->run();
}

start_accept();
}

void broadcast(std::string&& msg)
{
std::cout << '+' << std::endl;
if (connections.empty())
return;

for (auto const & x : connections)
x.lock()->enqueue_message(std::move(msg));
}
};

И есть место, где код перестает работать:

class tcp_connection_ui : std::enable_shared_from_this<tcp_connection_ui>
{
public:
using pointer = std::shared_ptr<tcp_connection_ui>;

static pointer create(tcp::socket socket)
{
return std::make_shared<tcp_connection_ui>(tcp_connection_ui{ std::move(socket) });
}

void run()
{
ws.async_accept(boost::asio::bind_executor(strand, std::bind(
&tcp_connection_ui::on_accept, shared_from_this(),
std::placeholders::_1)));
} .../};

Если клиент пытается подключиться, значение shared_from_this в server :: handle_accept равно _Wptr = empty. Я думаю, у меня есть некоторые проблемы с пониманием io_context :: service и / или shared_from_this этой функцией. Любая помощь будет оценена.

1

Решение

Базовый класс должен быть унаследован публично:

class tcp_connection_ui : public std::enable_shared_from_this<tcp_connection_ui>

Иначе, make_shared или же shared_ptr не заметит этого и впоследствии не сможет инициализировать «скрытый» weak_ptr

2

Другие решения

Других решений пока нет …

По вопросам рекламы ammmcru@yandex.ru
Adblock
detector