SendMessage() 和 PostMessage() 正确用法

SendMessage() and PostMessage() proper usage

本文关键字:用法 SendMessage PostMessage      更新时间:2023-10-16

我在正确使用SendMessage()和PostMessage()时遇到了问题。我正在尝试做的事情是在我的窗口过程中SendMessage(hWnd, WM_USER + 1, 0, 0);

LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
{
int wmId, wmEvent;
PAINTSTRUCT ps;
HDC hdc;
switch (message)
{
case WM_COMMAND:
    wmId    = LOWORD(wParam);
    wmEvent = HIWORD(wParam);
    // Parse the menu selections:
    switch (wmId)
    {
    case WM_CREATE:
        break;
    case IDM_ABOUT:
        DialogBox(hInst, MAKEINTRESOURCE(IDD_ABOUTBOX), hWnd, About);
        break;
    case IDM_EXIT:
        DestroyWindow(hWnd);
        break;
    case WM_USER:
        break;
    case WM_USER + 1:
        break;
    default:
        if (grid.ProcessEvent(wmId, wmEvent))
        {
            SendMessage(hWnd, WM_USER + 1, 0, 0);
            break;
        }
        return DefWindowProc(hWnd, message, wParam, lParam);
    }
    break;
case WM_DESTROY:
    PostQuitMessage(0);
    break;
default:
    return DefWindowProc(hWnd, message, wParam, lParam);
}
return 0;
}

我真的不确定为什么它不起作用,也许有人可以帮忙。我确定SendMessage(...)被调用,但它不会影响使用我的参数运行WndProc。

案例标签case WM_USER + 1:嵌套在内部案例语句中(打开wmId)。 它需要移出到 switch (message) case 语句中,因此它与 case WM_COMMAND:case WM_DESTROY: 处于同一嵌套级别。

以上也适用于case WM_USER:

SendMessage 被指定为在接收方窗口处理完消息之前不返回 - 它无法执行此操作,因为您在自己的 WndProc 中并自己发送消息。这是您应该使用PostMessage的情况之一。