关于mfc中的timer中使用messagebox和锁导致程序异常崩溃问题

今天一同事发现在timer函数中使用了锁,结果跑着跑着就崩溃了,不知道其中的原因。

我拿过代码来一看,一看也没看到原因。后来通过调试发现了问题,就是mfc中timer有点坑。

过程大概如此:

定义timer函数

onTimer()
{
    std::lock_guard<std::mutex> guard(mutexA);
    ...
    messagebox();
}

第一次运行时,显示了messagebox,需要手动关闭,没有进行关闭,第一次得到的锁因为messagebox没有释放;

过了一会,timer又被触发了,timer导致再次请求mutexA锁,发生了崩溃。

细看一下锁进行互斥保护,应该是没有问题,但是通过调试发现这两次请求锁,都是同一线程的请求,所以抛出了异常。

 

简单总结一下:

1、MFC中timer是一个非常神器的东西,使用了界面主线程,并且处理函数被阻止了,还能继续触发下一次的timer事件;【建议尽可能不用timer】

2、尽可能将代码中的异常进行捕获,获取详细的信息有利于问题排查;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值