QT程序报错 Debug Error abort() has been called

1.报错问题

QT程序报错 Debug Error abort() has been called_第1张图片

报错位置:

QT程序报错 Debug Error abort() has been called_第2张图片
代码流程:

  1. 在主线程中触发一个槽函数,执行数据转换的功能;
  2. 在该槽函数中,通过子线程拉起数据转换的函数,即RenderThread::Run();
  3. 槽函数原有代码中,不等待转换结束,数据转换留在后台进行,槽函数直接结束。
    QT程序报错 Debug Error abort() has been called_第3张图片

2.报错原因

  1. 用thread创建的多线程,在子线程中,控制主程序退出,如果没有等到子线程执行并结束线程,报错:Debug Error! Abort() has been called.
  2. 有些情况下,将debug模式改为release模式,不会出现该问题,具体原因待排查~

3.报错解决

修改槽函数,等待数据转换的线程结束后,再结束,如下:
QT程序报错 Debug Error abort() has been called_第4张图片
Tips:

  1. 代码中的IsRunOver()查询当前状态是加锁的,避免与数据转换线程的读写冲突;
  2. Sleep(5)的目的是每隔5ms查询一次,没必要一直查询,浪费CPU资源;
  3. 将程序从debug模式改为release模式运行;
  4. 对运行时间敏感的,建议不要通过读写状态来判断,可以直接通过锁状态来判断。

你可能感兴趣的:(debug记录)