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

我们的程序用到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。

 

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值