在客户那里崩溃本地正常,这种情况大家是如何调试QT程序的?

linda9989 2016-05-11 09:30:58
rt

在windows上面的qt creator开发的,在本地测试都是正常,在客户机上崩溃,大家如何调试?

VC/VS可以生成DMP + PDB进行源码级定位,而QT上面只能qDebug输LOG吗?
...全文
293 6 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
linda9989 2016-05-12
  • 打赏
  • 举报
回复
引用 5 楼 caojian005 的回复:
一般都是靠log吧 比如用宏调用每个函数 #define FUNCTION_CALL(LibraryName, CallerFunctionName, CalledFunctionName, ParaExpression, Expression) \ do { \ long (*pFunctionPtr) ParaExpression = (long(*) ParaExpression) LibraryName.resolve(#CalledFunctionName); \ if (NULL == pFunctionPtr) \ { \ qCritical() << #CallerFunctionName << " - " << #CalledFunctionName << " resolve fail!"; \ return false; \ } \ qDebug() << #CalledFunctionName << " - *****begin*****"; \ m_lErrorCode = 0; \ long lRetErrorCode = pFunctionPtr Expression; \ if (lRetErrorCode) \ { \ m_lErrorCode = lRetErrorCode; \ qCritical() << #CallerFunctionName << " - " << #CalledFunctionName << ", Error Code: " << lRetErrorCode; \ return false; \ } \ qDebug() << #CalledFunctionName << " - ******end******"; \ } while (0) qDebug这些是可以直接写入到log文件的,也可以自己写 崩溃的时候一般都是某个函数进去没出来,直接看log就知道了
用LOG效率低了啊,近百万行代码,任何一个地方都有可能崩,不能像VS这种PDB+DMP调吗?
FlyToTMoon 2016-05-12
  • 打赏
  • 举报
回复
一般都是靠log吧 比如用宏调用每个函数 #define FUNCTION_CALL(LibraryName, CallerFunctionName, CalledFunctionName, ParaExpression, Expression) \ do { \ long (*pFunctionPtr) ParaExpression = (long(*) ParaExpression) LibraryName.resolve(#CalledFunctionName); \ if (NULL == pFunctionPtr) \ { \ qCritical() << #CallerFunctionName << " - " << #CalledFunctionName << " resolve fail!"; \ return false; \ } \ qDebug() << #CalledFunctionName << " - *****begin*****"; \ m_lErrorCode = 0; \ long lRetErrorCode = pFunctionPtr Expression; \ if (lRetErrorCode) \ { \ m_lErrorCode = lRetErrorCode; \ qCritical() << #CallerFunctionName << " - " << #CalledFunctionName << ", Error Code: " << lRetErrorCode; \ return false; \ } \ qDebug() << #CalledFunctionName << " - ******end******"; \ } while (0) qDebug这些是可以直接写入到log文件的,也可以自己写 崩溃的时候一般都是某个函数进去没出来,直接看log就知道了
linda9989 2016-05-12
  • 打赏
  • 举报
回复
引用 1 楼 czyt1988 的回复:
我想可以写log文件,进入关键函数的时候记录一下,至少能定位到函数,布置其他大牛是怎么做的
qdebug效率也太低了吧,如果近百万行的代码,要是靠LOG,会死的~~
linda9989 2016-05-12
  • 打赏
  • 举报
回复
引用 2 楼 xytx_823 的回复:
QT库可以自己编译,dump一样可以定位到地方
这种是编译QT库的PDB文件,只能定位QT库函数,最主要是的QT生成的程序的PDB文件,没有程序的PDB一样定位不到的
xytx_823 2016-05-11
  • 打赏
  • 举报
回复
QT库可以自己编译,dump一样可以定位到地方
尘中远 2016-05-11
  • 打赏
  • 举报
回复
我想可以写log文件,进入关键函数的时候记录一下,至少能定位到函数,布置其他大牛是怎么做的

16,817

社区成员

发帖
与我相关
我的任务
社区描述
Qt 是一个跨平台应用程序框架。通过使用 Qt,您可以一次性开发应用程序和用户界面,然后将其部署到多个桌面和嵌入式操作系统,而无需重复编写源代码。
社区管理员
  • Qt
  • 亭台六七座
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧