C/C++子线程exit(0)退出时崩溃产生core文件

博客探讨了C++中单例类在接收到特殊信号后使用exit(0)退出程序时产生core文件的问题。原因是线程资源未正确回收,静态单例在程序退出时延迟析构,导致join无法执行。解决方案是在线程创建时使用detach,确保线程独立运行。文章提醒程序员在遇到类似问题时,应检查线程是否已join或detach。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题:

        程序中某个单例类在收到特殊信号后回调用exit(0)退出整个程序,但退出时总是产生core文件,文件不大,打开core文件堆栈都是些问号。只能review代码找bug。最后发现是线程资源没有回收,以下面这段代码分析下崩溃的原因。

以上代码看似人畜无害,实则运行就崩。如果将static test aa;去掉static,也不会蹦,但C++中单例一般都是申明个静态变量,返回其引用,这样会导致这个变量在程序退出的最后才析构,所以走不到析构的joinI()语句,即使走到,不是他的父线程调用的jion也不行。

解决方法:

        如果不需要再和父线程通信,直接在创建线程的时候设置detach(),这样就不会崩了。

结论:

        发现调用exit函数后程序产生core,先检查下退出的线程是不是没有被join或者设置detach。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值