C ++: BOOST-ASIO Ни один сервер не вызывает сбой клиента?

Следующий код вылетает на разъеме boost::asio::connect(s, iterator); с выводом:

before connector:
This application has requested the Runtime to terminate it in an unusual way.
Please contact the application's support team for more information.

Process returned 3 (0x3)   execution time : 1.281 s
Press any key to continue.

У меня нет сервера, работающего на порте 4001 с подключенным локальным узлом, и я подумал, есть ли способ предотвратить возникновение этого сбоя в случае, если сервер по какой-то причине не работает, но клиент все равно может запустить программное обеспечение. Другими словами, есть ли способ узнать, существует ли сервер без сбоя программы?

Вот код

//
// blocking_tcp_echo_client.cpp
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
// Copyright (c) 2003-2012 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)
//

#include <cstdlib>
#include <cstring>
#include <iostream>
#include <boost/asio.hpp>

using boost::asio::ip::tcp;

enum { max_length = 1024 };

int main(int argc, char* argv[])
{
//try
// {
//if (argc != 3)
//{
//  std::cerr << "Usage: blocking_tcp_echo_client <host> <port>\n";
//  return 1;
//}

boost::asio::io_service io_service;

tcp::resolver resolver(io_service);
//tcp::resolver::query query(tcp::v4(), argv[1], argv[2]);
tcp::resolver::query query(tcp::v4(), "127.0.0.1", "4001");
tcp::resolver::iterator iterator = resolver.resolve(query);

tcp::socket s(io_service);
std::cout << "before connector: ";
boost::asio::connect(s, iterator);
std::cout << "after connector: ";
using namespace std; // For strlen.
std::cout << "Enter message: ";
char request[max_length];
std::cin.getline(request, max_length);
size_t request_length = strlen(request);
boost::asio::write(s, boost::asio::buffer(request, request_length));

char reply[max_length];
size_t reply_length = boost::asio::read(s,
boost::asio::buffer(reply, request_length));
std::cout << "Reply is: ";
std::cout.write(reply, reply_length);
std::cout << "\n";
//}
//catch (std::exception& e)
//{
//  std::cerr << "Exception: " << e.what() << "\n";
//}

return 0;
}

0

Решение

boost::asio::connect выдает ошибку. Таким образом, блок try {} и блок catch {}, которые закомментированы, будут полезны для обнаружения ошибки, а не сбоя.

resolver.resolve (query) возвращает .end () вместо действительного итератора, если порт не найден, поэтому вы можете сначала проверить итератор, прежде чем пытаться вызвать connect

Из форсированной документации:

  • @ throws boost :: system :: system_error Брошенный при неудаче. Если последовательность
  • пустой, связанный код ошибки @c — boost :: asio :: error :: not_found.
  • В противном случае содержит ошибку с последней попытки подключения.
3

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

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

По вопросам рекламы [email protected]