c++ - boost::asio 暂停时抛出异常

标签 c++ xcode exception boost-asio breakpoints

我有一个程序使用 boost::asio 连接到远程机器,然后重复打印它接收到的任何内容。问题是,每当我暂停它或在它运行时对断点进行任何更改时,都会从 read_until() 内部某处抛出异常。为什么会发生这种情况,我应该怎么做?

这是在运行 OS X 10.8.2、Xcode 4.4.1 和 Apple clang 4.0 的 Mac 上运行的。暂停程序后抛出异常时的堆栈跟踪:

* thread #1: tid = 0x1d07, 0x00007fff86bc9d46 libsystem_kernel.dylib`__kill + 10, stop reason = signal SIGABRT
    frame #0: 0x00007fff86bc9d46 libsystem_kernel.dylib`__kill + 10
    frame #1: 0x00007fff8ec40df0 libsystem_c.dylib`abort + 177
    frame #2: 0x00007fff8c49ca17 libc++abi.dylib`abort_message + 257
    frame #3: 0x00007fff8c49a3c6 libc++abi.dylib`default_terminate() + 28
    frame #4: 0x00007fff8d05e887 libobjc.A.dylib`_objc_terminate() + 111
    frame #5: 0x00007fff8c49a3f5 libc++abi.dylib`safe_handler_caller(void (*)()) + 8
    frame #6: 0x00007fff8c49a450 libc++abi.dylib`std::terminate() + 16
    frame #7: 0x00007fff8c49b5b7 libc++abi.dylib`__cxa_throw + 111
    frame #8: 0x00000001000043df test`void boost::throw_exception<boost::system::system_error>(boost::system::system_error const&) + 111 at throw_exception.hpp:66
    frame #9: 0x0000000100004304 test`boost::asio::detail::do_throw_error(boost::system::error_code const&, char const*) + 68 at throw_error.ipp:38
    frame #10: 0x0000000100004272 test`boost::asio::detail::throw_error(boost::system::error_code const&, char const*) + 50 at throw_error.hpp:42
    frame #11: 0x0000000100002479 test`unsigned long boost::asio::read_until<boost::asio::ssl::stream<boost::asio::basic_stream_socket<boost::asio::ip::tcp, boost::asio::stream_socket_service<boost::asio::ip::tcp> > >, std::allocator<char> >(boost::asio::ssl::stream<boost::asio::basic_stream_socket<boost::asio::ip::tcp, boost::asio::stream_socket_service<boost::asio::ip::tcp> > >&, boost::asio::basic_streambuf<std::allocator<char> >&, std::string const&) + 73 at read_until.hpp:98
    frame #12: 0x00000001000012c5 test`main + 581 at main.cpp:21
    frame #13: 0x00007fff8983e7e1 libdyld.dylib`start + 1

最佳答案

当您暂停程序时,实际的暂停是通过向它发送一个 POSIX 信号 (SIGSTOP) 来完成的。其影响之一是系统调用(例如 Boost 将在内部使用的 read())返回一个错误,EINTR。这将触发 read_until 的错误处理代码,如您所见,它会引发异常。

如果你想正确处理这个问题,你可能想使用带有 boost::system::error_code 参数的重载,检查 .value() EINTR(在 errno.h 中定义),然后重试读取。

这看起来像

boost::system::error_code error;
boost::asio::streambuf message;
do {
    boost::asio::read(socket, message, boost::asio::transfer_exactly(body_size), error);
} while (error.value() == EINTR);

关于c++ - boost::asio 暂停时抛出异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12709769/

相关文章:

c++ - 如何在 C++ 中存储 1000000 位整数

python自定义现有的内置异常

c++ - 如何使模拟对象在 Google Mock 中引发异常?

c++ - 如何在矩阵中搜索相同值的区域?

c++ - 我的 shared_ptr 初始化列表代码有什么问题?

c++ - 什么时候在 C++ 类中使用关键字 "static"?

ios - 从核心数据中删除实体

xcode - 命令行工具的静态分析问题

ios - 将保存的关键数据加载到UITableView

scala - 获取 URL 时最好返回 None 还是抛出异常?