Qt SIGABRT备选消息
Qt SIGABRT alternative message?
我使用的是Qt5.9,一个简单的检查:
assert(pobjNode != NULL);
将导致显示Qt Signal Received error(Qt信号接收错误)对话框,该对话框没有提供任何关于问题所在或是什么的有用信息。
有没有办法用更有用的东西来代替这些无用的信息?
我想的是一种设置对话框的方法,以便在出现错误时显示可能的错误。
Q_ASSERT
是一个自定义断言宏,据说它增强了标准assert
函数。
错误消息由qFatal()
处理,它在某些平台上的表现可能比标准断言宏稍好。例如,在Windows上,它将在断言失败时触发Visual Studio调试器,而不是仅调用abort()
。
您还可以将Qt错误消息函数(如qFatal
)的输出重定向到您的自定义消息处理程序(使用qInstallMessageHandler())。例如,如果您想将错误消息重定向到一个文件,它可能很有用。
还要注意,Q_ASSERT
被宏QT_NO_DEBUG
禁用(而assert
被NDEBUG
禁用):这可以用于在Qt相关代码和其他代码之间分离断言。
Q_ASSERT_X
如果test为false,则打印消息内容以及位置、源文件名和行号。如果test为false,则打印消息内容、位置、源文件名和行号。示例:
// File: div.cpp
#include <QtGlobal>
int divide(int a, int b)
{
Q_ASSERT_X(b != 0, "divide", "division by zero");
return a / b;
}
阅读有关测试和调试的更多信息。
您可以定义自己的MY_ASSERT
宏。在Linux上,它甚至可以调用另一个使用Glibc回溯函数或Ian Taylor的libbacktrace库的函数(前提是您的代码是使用g++ -g
使用DWARF调试信息编译的),并可能在模式对话框或stderr上显示这些信息。然而,它可能不应该回来。另请阅读有关Qt和Unix信号以及信号安全的内容(7)。
但是assert
检测到一个您应该纠正的错误。尽量避免发送带有此类程序员错误的代码。
在Linux上,通常的assert
(它是在/usr/include/assert.h
中定义的宏)将在出现故障时调用__assert_fail
(在C库中,但您可以自己重新定义它),后者将间接调用abort
,后者间接生成一个核心转储,您可以使用gdb
调试器在死后检查该转储。您只需要启用核心转储(使用bash终端中内置的ulimit -c
)。
- boost::进程间消息队列引发错误
- 在线编译器中的分段C++没有打印消息
- C++错误消息*成员参考.**初学者*
- 在createdialog创建的窗口中捕获用于编辑控件的OnMouseMove消息
- 要与"if constexpr"一起使用的编译时消息(在预处理器之后)
- 如何通过参数抛出错误消息
- 从服务器传输到客户端的消息不会出现
- ROS2 动态消息模板
- C++秘密消息学校作业
- glad 导致 glfwSwapBuffers 返回错误消息
- C++入门 5 版:类消息和文件夹
- FindPackageHandleStandardArgs.cmake:137 的 CMake 错误(消息):找不到 Boost (缺少:正则表达式)(找到合适的版本"1.72.0",
- 如何处理从一个对象传递到另一个在C++中具有公共抽象类的对象的消息
- 如何接受 [ENTER] 键作为无效输入并发送错误消息
- 由于无效的 ValidateRgn() 子窗口不会收到WM_PAINT消息
- "string.h"在构建适用于iOS的qt应用程序中找不到消息
- 中止信号来自 C++ 中的中止(3) (SIGABRT)
- 如何将 Firebase 与基于 Linux 的客户端应用配合使用,以便与服务器进行双向消息通信
- 重新定义预定义的 errno 错误消息 (E2BIG)
- Qt SIGABRT备选消息