GetMessage第二个参数常见错误的解释

来源:互联网 发布:mac 显示.ds store 编辑:程序博客网 时间:2024/05/16 13:07
今天无意中写错了GetMessage的第二个参数,本应该是填NULL的,但是我填写了使用CreateWindow()所返回的窗口句柄,导致在调试时,窗口被销毁了,但是进程却没有清除。这个问题最终在MSDN中找到了答案。下面是百度的说明。 
GetMessage(LPMSG lpMsg,HWND hWnd,UINT wMsgFilterMin,UINT wMsgFilterMax)
参数:
lpMsg:指向MSG结构的指针,该结构从线程消息队列里接收消息信息。
hWnd:取得其消息的窗口的句柄。当其值取NULL时,GetMessage为任何属于调用线程的窗口检索消息,线程消息通过PostThreadMessage寄送给调用线程。
wMsgFilterMin:指定被检索的最小消息值的整数。
wMsgFilterMax:指定被检索的最大消息值的整数。
返回值:如果函数取得WM_QUIT之外的其他消息,返回非零值。如果函数取得WM_QUIT消息,返回值是零。如果出现了错误,返回值是-1。例如,当hWnd是无效的窗口句柄或lpMsg是无效的指针时。若想获得更多的错误信息,请调用GetLastError函数。

从说明中可以知道,第二个参数是,消息来源的窗口句柄。这里我直接就很自然的想到我接受的窗口消息不就是从CreateWindow所创建的窗口实例返回的句柄吗?但是这样的想法导致了,在程序关闭时出现了异常。因为GetMessage第二个参数如果是一个无效的句柄时,函数就会返回-1。这里如果填上CreatWindwo返回的窗口句柄会怎么样呢,这里在窗口正常运行时是没有问题的,但是在关闭过程中。当点击X,关闭程序,发送WM_CLOSE消息,并处理后调用DestroyWindow()发送WM_DESTROY消息,于是窗口被销毁,再经过处理发送了WM_QUIT消息,被GetMessage取到。但是因为在上面的WM_DESTROY消息时窗口就被销毁了,于是当时的句柄已经失效,于是这里GetMessage会返回-1.于是导致消息循环成了一个死循环。于是进程并不会被清除出内存。
0 0
原创粉丝点击