ZMQ::send() 抛出异常并终止 QNX 进程.为什么以及如何从中恢复?
ZMQ::send() throws an exception and kills the QNX-process. Why and how to recover from it?
ZMQ::send()
抛出异常并终止进程。
为什么以及如何从中恢复。
我在 QNX 版本 6.5.0 上使用 ZeroMQREQ/REP
模式。预期的catch{}
块不会收到此异常。
这是 gdb 跟踪:
(gdb) bt
#0 0xb033e4a1 in SignalKill () from /opt/qnx650/target/qnx6/x86/lib/libc.so.3
#1 0xb032d0ee in raise () from /opt/qnx650/target/qnx6/x86/lib/libc.so.3
#2 0xb032b3a8 in abort () from /opt/qnx650/target/qnx6/x86/lib/libc.so.3
#3 0xb835c077 in std::do_abort () from /opt/qnx650/target/qnx6/x86/lib/libcpp.so.4
#4 0xb835c01e in std::terminate () from /opt/qnx650/target/qnx6/x86/lib/libcpp.so.4
#5 0xb8354ff3 in __cxa_throw () from /opt/qnx650/target/qnx6/x86/lib/libcpp.so.4
#6 0x080596bc in zmq::detail::socket_base::send (this=0x8071070, msg_=@0x7b22d38)
at /home/bindhu/rtcs/libzmq/include/zmq.hpp:1299
#7 0x0805b0a4 in dblog::SendPacketToDBLogger (this=0x8071068, ipc_can_msg=
{type = 0, timestamp = 1590330536976, can_id = 352260142, data = 2511882692165894191})
at /home/user/rtcs/canvehicle/dblog.cpp:203
#8 0x080530e3 in send_version_request (type=0 ' ', module=47 '/')
at /home/user/rtcs/canvehicle/CanVehicle.cc:4736
#9 0x08053f50 in p_thread_kalmar_version (arg=0x0)
at /home/user/rtcs/canvehicle/CanVehicle.cc:4749
#10 0xb0320390 in ?? () from /opt/qnx650/target/qnx6/x86/lib/libc.so.3
这是我的代码片段。
dblog::dblog() :
context(1), socket(context, ZMQ_REQ) {
zmq_setsockopt (socket, ZMQ_LINGER, "", 0);
}
void dblog::Init() {
socket.connect("tcp://127.0.0.1:5555");
}
zmq::message_t create_values(protoTable.ByteSizeLong() + sizeof(uint16_t));
*((uint16_t*)create_values.data()) = TABLEMSG_ID; // ID
protoTable.SerializeToArray(create_values.data() + sizeof(uint16_t), protoTable.ByteSizeLong());
zmq::message_t reply;
try {
int returnv = socket.send(create_values,ZMQ_NOBLOCK);
socket.recv(&reply);
}
catch (int e)
{
std::cout << "SPD exception e : " << e << std::endl;
}
如果遵循 dbg((-output,则报告的行(如果使用最新版本(与ZMQ_CPP11#ifdef
块中template<int Opt, class T, bool BoolUnit = false> struct integral_option{}
的模板定义相关:
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ zmq.hpp:1290
#ifdef ZMQ_CPP11
namespace sockopt
{
// There are two types of options,
// integral type with known compiler time size (int, bool, int64_t, uint64_t)
// and arrays with dynamic size (strings, binary data).
// BoolUnit: if true accepts values of type bool (but passed as T into libzmq)
template<int Opt, class T, bool BoolUnit = false> struct integral_option
{
};
...
} // namespace sockopt
#endif // ZMQ_CPP11
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ zmq.hpp:1577
如果源代码和C++版本 11 都适合并且正常工作,请添加更多调试启用代码,以便在调用实际的.send()
-方法之前检查create_values
变量的验尸内容。
一些assert()
-s 也是公平的,例如
assert( socket.connect() == 0
&& "INF:: a call to .connect()-method failed, better inspect the <errno>"
);
或
assert( 0 == zmq_setsockopt( socket, ZMQ_LINGER, "", 0 )
&& "INF:: a call to zmq_setsockopt() API failed, better inspect the <errno>"
);
在这里,我不敢满足 API 定义,所以宁愿调用
zmq_setsockopt( socket, ZMQ_LINGER, &linger, sizeof (linger) )
相关文章:
- 为什么"do while"循环不断退出,即使条件计算结果为 false?
- 为什么在全局范围内使用"extern int a"似乎不行?
- 为什么在popback()操作之后,它仍然打印完整的矢量
- 为什么随机数生成器不在void函数中随机化数字,而在main函数中随机化
- 为什么两个不同的未命名名称空间可以共存于一个cpp文件中
- 为什么会发生堆损坏
- 为什么使用 "this" 指针调用派生成员函数?
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 为什么比较运算符如此快速
- 为什么 Serial.println(<char[]>);返回随机字符?
- 为什么这个运算符<重载函数对 STL 算法不可见?
- 为什么不;名字在地图上是按顺序排列的吗
- 我的字符计数代码计算错误.为什么
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 为什么我的C#代码在调用回C++COM直到Task时会暂停.等待/线程.加入
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 为什么野牛仍在使用"int yylex(void)",却找不到"int yylex(YYS
- ZMQ::send() 抛出异常并终止 QNX 进程.为什么以及如何从中恢复?
- 为什么mstats和malloc_zone_statistics在释放后不显示恢复的内存
- 在OpenGL中启用深度测试后,我的整个屏幕是空白的(恢复为清晰的颜色)-为什么