今天一同事发现在timer函数中使用了锁,结果跑着跑着就崩溃了,不知道其中的原因。
我拿过代码来一看,一看也没看到原因。后来通过调试发现了问题,就是mfc中timer有点坑。
过程大概如此:
定义timer函数
onTimer()
{
std::lock_guard<std::mutex> guard(mutexA);
...
messagebox();
}
第一次运行时,显示了messagebox,需要手动关闭,没有进行关闭,第一次得到的锁因为messagebox没有释放;
过了一会,timer又被触发了,timer导致再次请求mutexA锁,发生了崩溃。
细看一下锁进行互斥保护,应该是没有问题,但是通过调试发现这两次请求锁,都是同一线程的请求,所以抛出了异常。
简单总结一下:
1、MFC中timer是一个非常神器的东西,使用了界面主线程,并且处理函数被阻止了,还能继续触发下一次的timer事件;【建议尽可能不用timer】
2、尽可能将代码中的异常进行捕获,获取详细的信息有利于问题排查;