2 yangkunqiankun yangkunqiankun 于 2016.04.26 01:22 提问

Windows程序设计产生的消息问题 2C

程序源码如下:
#include
#pragma comment(lib,"WINMM.LIB")
LRESULT CALLBACK WndProc(HWND, UINT, WPARAM, LPARAM);

int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance,
PSTR szCmdLine, int iCmdShow)
{
static TCHAR szAppName[] = TEXT("Hello world!");
HWND hwnd;
MSG msg;
WNDCLASS wndclass;

wndclass.style = CS_HREDRAW | CS_VREDRAW;
wndclass.lpfnWndProc = WndProc;
wndclass.cbClsExtra = 0;
wndclass.cbWndExtra = 0;
wndclass.hInstance = hInstance;
wndclass.hIcon = LoadIcon(NULL, IDI_APPLICATION);
wndclass.hCursor = LoadCursor(NULL, IDC_HAND);
wndclass.hbrBackground = (HBRUSH)GetStockObject(WHITE_BRUSH);
wndclass.lpszMenuName = NULL;
wndclass.lpszClassName = szAppName;
if (!RegisterClass (&wndclass))
{
    MessageBox(NULL, TEXT("This program requires Windows NT!"), szAppName, MB_ICONERROR);
    return 0;
}
hwnd = CreateWindow(szAppName,
    TEXT("The Hello Program"),
    WS_OVERLAPPEDWINDOW,
    CW_USEDEFAULT,
    CW_USEDEFAULT,
    CW_USEDEFAULT,
    CW_USEDEFAULT,
    NULL,
    NULL,
    hInstance,
    NULL);
ShowWindow(hwnd, iCmdShow);
UpdateWindow(hwnd);
while (GetMessage(&msg, NULL, 0, 0))
{
    TranslateMessage(&msg);
    DispatchMessage(&msg);
}
return msg.wParam;

}

LRESULT CALLBACK WndProc(HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam)
{
HDC hdc;
PAINTSTRUCT ps;
RECT rect;
switch (message)
{
case WM_CREATE:
PlaySound(TEXT ("hellowin.wav"), NULL, SND_FILENAME | SND_ASYNC);
return 0;
case WM_PAINT:
hdc = BeginPaint(hwnd, &ps);
GetClientRect(hwnd, &rect);
PlaySound(TEXT("hellowin.wav"), NULL, SND_FILENAME | SND_ASYNC);
DrawText(hdc, TEXT("Hello, Windows 98!"), -1, &rect,
DT_SINGLELINE | DT_CENTER | DT_VCENTER);
EndPaint(hwnd, &ps);
return 0;
case WM_DESTROY:
PostQuitMessage(0);
return 0;
}
return DefWindowProc(hwnd, message, wParam, lParam);
}

为了能够清楚程序运行机制,采取单步调试,发现在执行CreateWindow()之后,程序跳转到switch(message),接着跳转到return DefWindowProc(hwnd, message, wParam, lParam);这一句,想问一下CreateWindow()这一句不是只产生WM_CREATE这个消息,而是会产生一些其他程序中不关心的消息之后才有WM_CREATE这个消息入队列?不然为什么没有直接执行case,而是执行了默认的消息处理函数?

2个回答

caozhy
caozhy   Ds   Rxr 2016.04.26 04:49

https://msdn.microsoft.com/en-us/library/windows/desktop/ms632619(v=vs.85).aspx

说的很清楚

(The message is sent before the function returns.)

你说执行完CreateWindow()之后,那么这个消息早处理过了。

lboych
lboych   2016.05.02 09:50

消息进入队列,等待处理。在你想要的地方直接下断点就好了

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!
其他相关推荐
windows程序设计(14):鼠标消息详解
关于鼠标的一些细节知识: 通常,我们发消息时,都是对一个特定的窗口,但是对于鼠标消息却不然:只要鼠标跨越窗口或者在某窗口中按下鼠标按键,那么窗口消息处理程序就会收到鼠标消息,而不管该窗口是否活动或者是否拥有输入焦点。鼠标消息一个有21种:10个显示区域消息,11个非显示区域消息 显示区域鼠标消息 当鼠标移过窗口的显示区域时,窗口消息处理程序收到WM_MOUSEMOVE消息。 当在窗口的显示
windows程序设计--鼠标消息---程序击中测试
Windows程序设计 第五版 Charles PetZold  P232 /*------------------------------------------------- CHECKER1.C -- Mouse Hit-Test Demo Program No. 1 (c) Charles Petzold, 1998 --------
Windows应用程序常用消息
WM_LBUTTONDOWN产生单击鼠标左键的消息该消息包含了长参数(IParam)和字参数(wParam)IParam 低字节:包含当前光标的x坐标值 x = LOWORD(IParam); 高字节:包含当前光标的y坐标值 y = HIWORD(IParam); wParam 包含一整数值,用来标识鼠标键 按下的状态 通过switch - case构架来使用类似的还有: MK_LBUTTO
windows基础应用程序编程(七)鼠标消息
上一篇中,我们介绍了键盘消息,接下来,我们来了解一下鼠标消息。 在上一篇中,我们知道Windows只把键盘消息发送给拥有输入焦点的窗口。鼠标消息与此不同,只要鼠标跨越窗口或者在某窗口中按下鼠标键,那么窗口过程就会受到鼠标消息,而不管该窗口是否活动或者是否拥有输入焦点。同键盘消息类似,鼠标消息也简单的可以分为客户区鼠标消息和非客户区鼠标消息。 客户区鼠标消息 当鼠标通过窗口的客户区时,窗口过程
Windows笔试题基础(第一篇
共享内存是在两个正在运行的进程之间传递数据的一种非常有效的方式。共享内存允许两个不相关的进程访问同一个逻辑内存。由于它并没有提供同步机制,所以我们通常需要用其他的机制来同步访问共享的内存。
Windows窗口程序从创建到关闭产生的消息
Windows是消息驱动的,理解消息机制及消息循环是特别重要。知道在什么情况下产生什么消息会让我们对程序有更好的控制。Windows给应用程序发消息,有些会加入应用程序的消息队列,也是就是队列消息。有些直接调用窗口消息处理程序,不会加入到消息队列,这部分为非队列消息。 下面分析一下一个应用程序从创建到结束产生的消息。 先给出测试用的程序,当然是一个非常经典的结构: #incl
通信信号与系统分析(三 模拟调制)
本篇讨论各种模拟调制与解调系统的性能,包括幅度调制(AM)和角度调制(包括频率调制(FM)和相位调制(PM))。
产生消失的梯度问题的原因
产生消失的梯度问题的原因先看一个极简单的深度神经网络:每一层都只有一个单一的神经元。如下图:代价函数C对偏置b1的偏导数的结果计算如下:先看一下sigmoid 函数导数的图像:该导数在σ′(0) = 1/4时达到最高。现在,如果我们使用标准方法来初始化网络中的权重,那么会使用一个均值为0 标准差为1 的高斯分布。因此所有的权重通常会满足|wj|<1。从而有wjσ′(zj) < 1/4。...
windows程序设计之捕获鼠标
一般,只有鼠标在CWnd的客户区内,你才能接受到鼠标消息。 调用SetCapture后,即使鼠标移动出客户区,你也可以接受到鼠标消息。不过系统中只能有一个程序调用SetCapture,所以你需要在不使用时调用ReleaseCapture释放。而GetCapture可以知道当前哪个窗口调用了SetCapture。
WM_DESTROY WM_CLOSE WM_QUIT三个消息的理解
DefWindowProc对WM_CLOSE的处理是调用DestroyWindow, DestroyWindow完成窗口的清理工作,最后像窗口过程发送WM_DESTROY。对于WM_DESTROY,DefWindowProc不会处理。也就是说,你如果不处理这个消息,虽然你的窗口已经销毁,但进程并不会结束。一般处理WM_DESTROY时都是释放资源(例如申请的内存等),然后调用PostQuitMes