QT程序崩溃记录1

1、错误1

ASSERT failure in QCoreApplication::sendEvent: “Cannot send events to objects owned by a different thread. Current thread 0x0x2599c080. Receiver ‘’ (of type ‘QNativeSocketEngine’) was created in thread 0x0x2b0776b0”
在这里插入图片描述
如下代码,直接在mainwindow中调用DisConnect,会导致程序崩溃,且报错如上图。
原因:m_serial被移到线程中,只能在线程中调用,不能在主线程中直接调用
解决方法:使用信号槽调用DisConnect
出错过程分析:

//1、构造函数中将类移到了线程中
    m_serial = NULL;
    m_th = new QThread();
    this->moveToThread(m_th);
//2、串口移到线程中
    m_serial = new QSerialPort();
    m_serial->moveToThread(m_th);
//3、断开连接
void ConnectSerial::DisConnect()
{
    qDebug() << "this thread 2" << QThread::currentThread() <<"id" << QThread::currentThreadId();
    if(m_serial != NULL)
    {
        if(m_serial->isOpen())
        {
            disconnect(m_serial,&QSerialPort::readyRead,this,&ConnectSerial::readData);
            m_serial->close();
        }
        delete m_serial;
        m_serial = NULL;
    }
}
//在mainwindow中直接调用函数
    m_SendSerial->DisConnect();

如下图:DisConnect函数所在线程与m_Serial所在线程不一致,DisConnect还在主线程中,
在这里插入图片描述

解决方法

//连接信号槽
    connect(this,&ConnectSerial::disConnect,this,&ConnectSerial::DisConnect);
//在mainwindow中调用信号
    m_SendSerial->disConnect();

如下图:DisConnect函数所在线程与mSerial所在线程一致。
在这里插入图片描述

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Qt 程序中捕获代码行数,可以使用 Qt 提供的异常处理机制来捕获程序崩溃时的错误信息,从而获取出错的代码行数。 以下是一个示例代码,演示了如何使用 Qt 异常处理机制捕获程序崩溃时的错误信息: ```cpp #include <QtCore> void myMessageOutput(QtMsgType type, const QMessageLogContext &context, const QString &msg) { QByteArray localMsg = msg.toLocal8Bit(); switch (type) { case QtDebugMsg: fprintf(stderr, "Debug: %s (%s:%u, %s)\n", localMsg.constData(), context.file, context.line, context.function); break; case QtWarningMsg: fprintf(stderr, "Warning: %s (%s:%u, %s)\n", localMsg.constData(), context.file, context.line, context.function); break; case QtCriticalMsg: fprintf(stderr, "Critical: %s (%s:%u, %s)\n", localMsg.constData(), context.file, context.line, context.function); break; case QtFatalMsg: fprintf(stderr, "Fatal: %s (%s:%u, %s)\n", localMsg.constData(), context.file, context.line, context.function); abort(); } } int main(int argc, char *argv[]) { qInstallMessageHandler(myMessageOutput); // ... // Your Qt code here // ... return 0; } ``` 在上面的代码中,我们使用了 `qInstallMessageHandler` 函数来设置自定义的消息输出函数 `myMessageOutput`,这个函数会被 Qt 调用来输出调试信息、警告信息、错误信息和致命错误信息。在 `myMessageOutput` 函数中,我们可以获取到错误发生的文件名、行数和函数名等信息,并将它们输出到标准错误流中。 当程序崩溃时,我们可以查看输出的错误信息,以获取出错的代码行数。如果是在开发阶段,可以使用 Qt Creator 的调试工具来单步调试程序,从而快速定位出错的代码行数。 ### 回答2: 在Qt程序中,当程序崩溃时,可以通过设置异常处理器来捕获代码行数。以下是一个简单的示例: ```cpp #include <QtCore> void myMessageOutput(QtMsgType type, const QMessageLogContext &context, const QString &msg) { QByteArray localMsg = msg.toLocal8Bit(); switch (type) { case QtDebugMsg: fprintf(stderr, "Debug: %s (%s:%u, %s)\n", localMsg.constData(), context.file, context.line, context.function); break; case QtWarningMsg: fprintf(stderr, "Warning: %s (%s:%u, %s)\n", localMsg.constData(), context.file, context.line, context.function); break; case QtCriticalMsg: fprintf(stderr, "Critical: %s (%s:%u, %s)\n", localMsg.constData(), context.file, context.line, context.function); break; case QtFatalMsg: fprintf(stderr, "Fatal: %s (%s:%u, %s)\n", localMsg.constData(), context.file, context.line, context.function); abort(); // 程序崩溃 } } int main(int argc, char *argv[]) { qInstallMessageHandler(myMessageOutput); // 设置自定义的消息处理器 QApplication app(argc, argv); // ... // 这里添加你的Qt程序代码 return app.exec(); } ``` 在上面的示例中,通过自定义的`myMessageOutput`函数来处理Qt消息输出。当调用`qFatal`或其他会导致程序崩溃的情况时,我们可以在其中打印出发生崩溃的代码行数信息,并通过`abort()`函数使程序立即退出。 通过以上设置,当程序发生崩溃时,你可以在控制台中看到类似以下的输出: ``` Fatal: Some error message (path/to/file.cpp:42, functionName) ``` ### 回答3: 在Qt中,当程序发生崩溃时,可以使用Qt的异常处理机制来捕获代码行数。 首先,需要在代码中使用try-catch块来捕获异常。可以在主函数中或者其他可能发生崩溃的地方放置try块。例如: ```cpp int main(int argc, char *argv[]) { QApplication a(argc, argv); try { // 你的程序代码 // ... return a.exec(); } catch (std::exception &e) { // 异常处理代码 qDebug() << "Exception caught: " << e.what(); } catch (...) { // 未知异常处理代码 qDebug() << "Unknown exception caught"; } return -1; } ``` 在catch块中,可以通过调用`e.what()`函数获取异常的详细信息,包括崩溃发生的位置。然而,默认情况下,`e.what()`只会返回异常类型的字符串,不包含代码行数。 为了获取代码行数,可以使用Qt的`qDebug()`函数以及预定义的`__FILE__`和`__LINE__`宏来动态记录代码行数。修改上述代码如下: ```cpp int main(int argc, char *argv[]) { QApplication a(argc, argv); try { // 你的程序代码 // ... return a.exec(); } catch (std::exception &e) { // 异常处理代码 qDebug() << "Exception caught at" << __FILE__ << ":" << __LINE__ << ": " << e.what(); } catch (...) { // 未知异常处理代码 qDebug() << "Unknown exception caught at" << __FILE__ << ":" << __LINE__; } return -1; } ``` 这样,在捕获到异常时,`qDebug()`函数将输出异常发生的文件名、行数以及异常类型的字符串。 通过这种方式,可以在Qt程序崩溃时方便地捕获代码行数,有助于定位和解决崩溃问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值