博主是Linux C/C++开发,这篇文章用于记录工作中的一点经验
QA提出这个bug后,交付我来修改,一开始我并没有复现此bug。但当我手速够快,程序一启动就马上停止时便会稳定复现
根据生成的core文件,查看bt堆栈信息,可以锁定到线程的jion()处
查看源代码
if(pThread) {
pThread->join();
delete pThread;
pThread = nullptr;
}
第一步,修改join()
为detach()
,再尝试复现,但程序并未崩溃,由此推测线程卡在了某处
对pThread所启线程加打印信息,重新复现bug,但日志中并未出现新增打印,推断线程并未启动,怀疑是未初始化
对线程定义处将 std::thread* pThread
修改为 std::thread* pThread = nullptr
果然解决
后续检查代码里其他线程是否有未初始化,结束。。。