我们的程序用到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。
详细调试过程后面有空整理一下发表。