WM_DESTROY、WM_CLOSE和WM_QUIT

一、理解之一

WM_CLOSE和WM_DESTROY同属窗口消息,WM_QUIT则不在窗口消息之列。三者先后执行顺序是WM_CLOSE、WM_DESTROY、WM_QUIT,但需要注意的是MFC窗口默认取消按钮函数OnCancel()是不会触发WM_CLOSE消息,只触发WM_DESTROY。

WM_CLOSE


当点击窗口右上角的 'X' 或使用SendMessage(WM_CLOSE)时,窗口就会收到WM_CLOSE消息。这个消息可以让DefWindowProc处理,也可以自己处理,例如询问用户是否保存更改等。如果用户选择“取消”,那么程序照常运行;如果用户确认要退出,窗口消失。这一消息处理完毕后,就调用DestroyWindow函数。

WM_DESTROY

 

 

DestroyWindow函数向窗口过程发送WM_DESTROY。虽然此时窗口已经销毁,但进程并不会结束。一般处理WM_DESTROY时都是释放资源(例如申请的内存等),处理完毕后调用PostQuitMessage函数。

 

WM_QUIT


PostQuitMessage会发送WM_QUIT给消息队列。注意,WM_QUIT永远不会到达窗口过程,因为GetMessage得到WM_QUIT后就会返回FALSE,从而结束消息循环,最后进程结束,程序退出。

 

二、理解之二

 

DefWindowProc对WM_CLOSE的处理是调用DestroyWindow, DestroyWindow完成窗口的清理工作,最后像窗口过程发送WM_DESTROY。对于WM_DESTROY,DefWindowProc不会处理。也就是说,你如果不处理这个消息,虽然你的窗口已经销毁,但进程并不会结束。一般处理WM_DESTROY时都是释放资源(例如申请的内存等),然后调用PostQuitMessage。
 PostQuitMessage会发送WM_QUIT给消息队列。注意,WM_QUIT永远不会到达窗口过程,因为GetMessage得到WM_QUIT后就会返回FALSE,从而结束消息循环,最后进程结束,程序退出。

 

从这里我们可以得出一些结论,当WM_CLOSE,WM_DESTROY,WM_QUIT被处理时,我们可以不用管系统或者我们对它做了什么,但是有一点可以肯定,窗口类的析构函数并没有被调用,至少从理论上是这么分析的,但是窗口的句柄等系统资源已经被关闭,释放。知道这些后我们可以做什么呢,因本人最近想关掉窗口句柄节省资源,依然可以使用窗口类中自定义的函数以及属性。析构函数没有被调用说明这个窗口类其实还存在。那我们就可以继续使用

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值