프로그램을 종결해도 프로세스가 계속 살아있습니다.
글쓴이: mydream / 작성시간: 일, 2016/01/10 - 2:16오후
부모윈도우의 프로세스 WinProc에서 자식윈도우를 만들고 자식 프로세스로 ChildProc를 만들었습니다. 그리고 실행해보면 자식 윈도우는 정상적으로 떴는데, 문제는 부모 윈도우를 닫을 때 계속 프로세스가 살아있네요. 문제가 ChildProc에서 처리가 잘못된 것 같은데, 어떻게 해야 프로세스 모두 종결시킬 수 있을까요?
#include <windows.h> #include <tchar.h> LRESULT CALLBACK WinProc(HWND, UINT, WPARAM, LPARAM); LRESULT CALLBACK ChildProc(HWND, UINT, WPARAM, LPARAM); HINSTANCE gIns; int APIENTRY WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpcmdline, int nShowCmd) { WNDCLASS wndCls; wndCls.cbClsExtra=0; wndCls.cbWndExtra=0; wndCls.hbrBackground=(HBRUSH)GetStockObject(WHITE_BRUSH); wndCls.hCursor=LoadCursor(NULL, IDC_ARROW); wndCls.hIcon=NULL; wndCls.hInstance=gIns=hInstance; wndCls.lpfnWndProc=WinProc; wndCls.lpszClassName=TEXT("windowfrompoint"); wndCls.lpszMenuName=NULL; wndCls.style=CS_HREDRAW | CS_VREDRAW; RegisterClass(&wndCls); wndCls.lpszClassName=TEXT("child window"); wndCls.hbrBackground=(HBRUSH)GetStockObject(BLACK_BRUSH); wndCls.lpfnWndProc=ChildProc; RegisterClass(&wndCls); HWND hwnd=CreateWindow( TEXT("windowfrompoint"), TEXT("windowfrompoint window"), WS_OVERLAPPEDWINDOW, 100, 100, 300, 300, NULL, NULL, hInstance, NULL ); ShowWindow(hwnd, nShowCmd); MSG message; while( GetMessage(&message, hwnd, 0, 0) ) { TranslateMessage(&message); DispatchMessage(&message); } return message.wParam; } HWND chWin; LRESULT CALLBACK WinProc(HWND hwnd, UINT message, WPARAM wparam, LPARAM lparam) { switch(message) { case WM_CREATE: { chWin=CreateWindow(TEXT("child window"), TEXT("child child"), WS_CHILD | WS_VISIBLE, 50, 50, 100, 100, hwnd, (HMENU)NULL, gIns, NULL); } return 0; case WM_DESTROY: //DestroyWindow(chWin); PostQuitMessage(0); return 0; } return DefWindowProc(hwnd, message, wparam, lparam); } LRESULT CALLBACK ChildProc(HWND hwnd, UINT message, WPARAM wparam, LPARAM lparam) { switch(message) { case WM_CREATE: MessageBox(hwnd, TEXT("child proc"), NULL, MB_OK); return 0; default: return DefWindowProc(hwnd, message, wparam, lparam); } }
Forums:
GetMessage()에서 반복되고 있습니다.
해결하려면. 몇가지 방법이 있습니다.
일반적인 사용을 한다.
- 자식 프로세스 생성을 SetWindowLong() CallWindowProc() 로 등록해서 사용
주기적으로 확인 한다.
- DWORD GetLastError()가 1400 잘못된 창 핸들입니다. ExitProcess();
입출력 루틴을 변경 한다.
- AllocConsole(); freopen("CONOUT$", "wt", stdout); FreeConsole(); 를 두고 종료
임의로 값을 지정해서 종료한다.
- 자식 윈도우 핸들이 NULL 이고. wParam 이 2 일 경우. break;
참고용으로 종료 루틴과 방식은 이런 내용이 있습니다.
WM_QUIT
WM_CLOSE
WM_DESTROY
WM_NCDESTROY
exit(0)
PostQuitMessage(0)
SendMessage(hChild, WM_DESTORY, 0, 0);
ExitProcess(0);
그외에. 외부 프로그램으로 종료하는 방법
----------------------------------------------------------------------------
젊음'은 모든것을 가능하게 만든다.
매일 1억명이 사용하는 프로그램을 함께 만들어보고 싶습니다.
정규 근로 시간을 지키는. 야근 없는 회사와 거래합니다.
각 분야별. 좋은 책'이나 사이트' 블로그' 링크 소개 받습니다. shintx@naver.com
찾았습니다. 제가 실수했네요.
어제 몇 시간 검토해서 겨우 찾았습니다. 메시지 루프에서 두 번재 인자에 NULL을 전달하지 않으니 그런 문제가 생기는군요. 쩝, 그게 왜 그런지는 모르겠지만요? 이유까지 알면서 하려면 너무 시간이 부족한지라 그냥 넘어가기로 했습니다. 혹시 그 이유좀 아시고 시간 되시면 이유좀 설명해주실 수 있을까요?
NULL 로 해도 종료되지 않고 있습니다.
자세한 내용은 MSDN에서 함수에 인자값. 리턴값. 오류값을 확인하고. 테스트해봐야 알거 같습니다.
되도록이면 잘 되는 책과 코드프로젝트 예제소스를 참고해보시기 바랍니다.
- Visual C++
- MFC
- Win32 API
- http://www.soen.kr/
- http://www.winapi.co.kr/
- http://www.codeproject.com/
- http://book.naver.com/
주의하실 사항을 알려드리겠습니다.
https://kldp.org/node/153831
----------------------------------------------------------------------------
젊음'은 모든것을 가능하게 만든다.
매일 1억명이 사용하는 프로그램을 함께 만들어보고 싶습니다.
정규 근로 시간을 지키는. 야근 없는 회사와 거래합니다.
각 분야별. 좋은 책'이나 사이트' 블로그' 링크 소개 받습니다. shintx@naver.com
댓글 달기