今天这个BUG再次证明了,凡事有果必有因

来源:互联网 发布:beyonce 知乎 编辑:程序博客网 时间:2024/05/01 05:05

我们的程序用到Flash控件进行互操作以提供更友好的界面。

为了屏蔽右键菜单,直接子类化了Flash窗口,用自己的窗口函数,在右键时不发送给Flash控件,自己处理。

测试中发现,一些情况下(主要是点击后开IE),关闭窗口销毁控件会导致崩溃。

 

1. 发现在ShellExecute这个API中会有消息循环,导致WM_CLOSE会在ShellExecute返回之前被处理

2. 改成异步ShellExecute后,发现还是会有问题,而且总是在WM_TIMER(0x0113)这个消息上。

3. Flash控件会不断生成WM_TIMER,并在其处理过程中会调用timeGetTime来进行计时。这会导致对ShellExecuteExW的间接调用,结果,是在CallWndProc返回前,窗口又被销毁了。

 

解决办法:

对窗口函数的调用前后进行嵌套计数。

父窗口在OnClose时,判断如果嵌套计数>0就不进行DestroyWindow,只是设置一个准备关闭的标志。

嵌套计数==0时,发出一个事件。父窗口收到事件后,判断准备关闭标志置上的情况下,进行DestroyWindow。

 

详细调试过程后面有空整理一下发表。