|  | 
        An iterator connect handler must meet the requirements for a handler.
        A value h of an iterator connect handler class should work correctly
        in the expression h(ec, i), where ec is an lvalue
        of type const error_code and i is an lvalue of
        the type Iterator used in the corresponding connect()
        or async_connect()` function.
      
A free function as an iterator connect handler:
void connect_handler(
    const asio::error_code& ec,
    asio::ip::tcp::resolver::iterator iterator)
{
  ...
}
An iterator connect handler function object:
struct connect_handler
{
  ...
  template <typename Iterator>
  void operator()(
      const asio::error_code& ec,
      Iterator iterator)
  {
    ...
  }
  ...
};
A lambda as an iterator connect handler:
asio::async_connect(...,
    [](const asio::error_code& ec,
      asio::ip::tcp::resolver::iterator iterator)
    {
      ...
    });
        A non-static class member function adapted to an iterator connect handler
        using std::bind():
      
void my_class::connect_handler(
    const asio::error_code& ec,
    asio::ip::tcp::resolver::iterator iterator)
{
  ...
}
...
asio::async_connect(...,
    std::bind(&my_class::connect_handler,
      this, std::placeholders::_1,
      std::placeholders::_2));
        A non-static class member function adapted to an iterator connect handler
        using boost::bind():
      
void my_class::connect_handler(
    const asio::error_code& ec,
    asio::ip::tcp::resolver::iterator iterator)
{
  ...
}
...
asio::async_connect(...,
    boost::bind(&my_class::connect_handler,
      this, asio::placeholders::error,
      asio::placeholders::iterator));