[/ / Copyright (c) 2003-2025 Christopher M. Kohlhoff (chris at kohlhoff dot com) / / Distributed under the Boost Software License, Version 1.0. (See accompanying / file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) /] [section:ResolveToken Resolve token requirements] A resolve token is a [link asio.overview.model.completion_tokens completion token] for completion signature `void(error_code, ip::basic_resolver_results)`, for a specified `InternetProtocol`. [heading Examples] A free function as a resolve token: void resolve_handler( const asio::error_code& ec, asio::ip::tcp::resolver::results_type results) { ... } A resolve token function object: struct resolve_handler { ... void operator()( const asio::error_code& ec, asio::ip::tcp::resolver::results_type results) { ... } ... }; A lambda as a resolve token: resolver.async_resolve(..., [](const asio::error_code& ec, asio::ip::tcp::resolver::results_type results) { ... }); A non-static class member function adapted to a resolve token using `std::bind()`: void my_class::resolve_handler( const asio::error_code& ec, asio::ip::tcp::resolver::results_type results) { ... } ... resolver.async_resolve(..., std::bind(&my_class::resolve_handler, this, std::placeholders::_1, std::placeholders::_2)); A non-static class member function adapted to a resolve token using `boost::bind()`: void my_class::resolve_handler( const asio::error_code& ec, asio::ip::tcp::resolver::results_type results) { ... } ... resolver.async_resolve(..., boost::bind(&my_class::resolve_handler, this, asio::placeholders::error, asio::placeholders::results)); Using [link asio.reference.use_future use_future] as a resolve token: std::future f = resolver.async_resolve(..., asio::use_future); ... try { asio::ip::tcp::resolver::results_type r = f.get(); ... } catch (const system_error& e) { ... } Using [link asio.reference.use_awaitable use_awaitable] as a resolve token: asio::awaitable my_coroutine() { try { ... asio::ip::tcp::resolver::results_type r = co_await resolver.async_resolve( ..., asio::use_awaitable); ... } catch (const system_error& e) { ... } } [endsect]