Как предотвратить запуск приложения Win32 в фоновом режиме после закрытия главного окна? - PullRequest
4 голосов
/ 05 марта 2012

Я новичок в Win32 API, но у меня средний опыт работы с C ++. В целях обучения я создал, согласно ссылкам, учебникам и примерам, очень простое приложение Win32.

Проблема в том, что после закрытия главного окна его процесс все еще выполняется в фоновом режиме. Как я могу предотвратить это? В моей функции WndProc у меня есть случай WM_DESTROY с DestroyWindow, но, похоже, он не работает. Код ниже:

#include <cstdio>
#include <cstdlib>

#ifdef UNICODE
#include <tchar.h>
#endif

#include <Windows.h>

HINSTANCE hinst;
HWND hwnd;

LRESULT CALLBACK WndProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam);

#ifdef UNICODE
int WINAPI _tWinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPTSTR lpCmdLine, int nCmdShow)
#else
int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow)
#endif
{
    MSG msg;
    WNDCLASSEX mainclass;
    BOOL bRet;
    UNREFERENCED_PARAMETER(lpCmdLine);

    mainclass.cbSize =          sizeof(WNDCLASSEX);
    mainclass.style =           CS_VREDRAW | CS_HREDRAW;
    mainclass.lpfnWndProc =     (WNDPROC) WndProc;
    mainclass.cbClsExtra =      NULL;
    mainclass.cbWndExtra =      NULL;
    mainclass.hInstance =       hInstance;
    mainclass.hIcon =           NULL;
    mainclass.hCursor =         LoadCursor(NULL, IDC_ARROW);
    mainclass.hbrBackground =   (HBRUSH) COLOR_WINDOW;
    mainclass.lpszMenuName =    NULL;
    mainclass.lpszClassName =   TEXT("MainWindowClass");
    mainclass.hIconSm =         NULL;

    if (!RegisterClassEx(&mainclass))
        return FALSE;

    hinst = hInstance;

    hwnd = CreateWindowEx(
        WS_EX_WINDOWEDGE,
        TEXT("MainWindowClass"),
        TEXT("Test Window"),
        WS_CAPTION | WS_VISIBLE | WS_SIZEBOX | WS_SYSMENU | WS_MINIMIZEBOX | WS_MAXIMIZEBOX,
        CW_USEDEFAULT,
        CW_USEDEFAULT,
        CW_USEDEFAULT,
        CW_USEDEFAULT,
        NULL,
        NULL,
        hinst,
        NULL);

    ShowWindow(hwnd, nCmdShow);
    UpdateWindow(hwnd);

    while ((bRet = GetMessage(&msg, NULL, 0, 0)) != 0)
    {
        if (bRet != -1)
        {
            TranslateMessage(&msg);
            DispatchMessage(&msg);
        }
    }
    return (int) msg.wParam;
}

LRESULT CALLBACK WndProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
{
    PAINTSTRUCT ps;
    switch(uMsg)
    {
    case WM_DESTROY:
        DestroyWindow(hwnd);
        break;
    case WM_PAINT:
        BeginPaint(hwnd, &ps);
        EndPaint(hwnd, &ps);
        break;
    default:
        return DefWindowProc(hwnd, uMsg, wParam, lParam);
    }
    return 0;
}

Ответы [ 2 ]

9 голосов
/ 05 марта 2012

Не звоните DestroyWindow(). Сообщение говорит вам, что ваше окно уже было уничтожено. Звоните PostQuitMessage(0), чтобы выйти из приложения.

2 голосов
/ 05 апреля 2013

В вашем WndProc добавьте регистр для WM_CLOSE и вызовите PostQuitMessage.

LRESULT CALLBACK WndProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
{
  case WM_CLOSE:
  PostQuitMessage(0);
  break;
  // other cases
}

Когда пользователь нажимает кнопку закрытия (или из меню sys), Windows публикует сообщение WM_CLOSE. Это приведет к закрытию вашего основного обработчика сообщений Windows. Это, в свою очередь, обеспечит правильное завершение работы вашего приложения.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...