Следующий код вылетает на разъеме 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;
}
boost::asio::connect
выдает ошибку. Таким образом, блок try {} и блок catch {}, которые закомментированы, будут полезны для обнаружения ошибки, а не сбоя.
resolver.resolve (query) возвращает .end () вместо действительного итератора, если порт не найден, поэтому вы можете сначала проверить итератор, прежде чем пытаться вызвать connect
Из форсированной документации:
Других решений пока нет …