개발/코더 탈출
Timer vs Thread+Sleep
-=HaeJuK=-
2024. 12. 24. 18:48
반응형
SetTimer vs Thread Sleep vs CreateTimerQueueTimer 비교
윈도우 애플리케이션에서 일정 시간 간격으로 작업을 수행하는 방법으로 SetTimer, Thread + Sleep, CreateTimerQueueTimer가 자주 사용됩니다. 각각의 방식은 동작 방식과 장단점이 다르며, 상황에 따라 적합한 방식이 달라집니다.
1. SetTimer
동작 방식: 일정 시간 간격으로 WM_TIMER
메시지를 메시지 큐에 추가하여 타이머 이벤트를 발생시킵니다. 메인 스레드에서 타이머 콜백이 처리됩니다.
SetTimer(hWnd, 1, 1000, NULL); // 1초마다 WM_TIMER 발생 switch (message) { case WM_TIMER: if (wParam == 1) { SendData(); // 데이터 전송 } break; }
장점
- 비동기 처리 - GUI 응답성을 유지합니다.
- 간단한 구현 - 윈도우 메시지 루프 기반으로 동작합니다.
단점
- 정확성 낮음 - GUI가 멈추거나 메시지 큐가 밀리면 지연됩니다.
- 메시지 루프 필요 - 콘솔 애플리케이션에서는 사용하기 어렵습니다.
2. Thread + Sleep
동작 방식: 별도의 스레드를 생성하고 일정 시간 동안 스레드를 블로킹합니다.
std::thread([]() { while (true) { SendData(); Sleep(1000); // 1초 대기 } }).detach();
장점
- 정확성 높음 - 지정한 시간 동안 정확하게 대기합니다.
- 메시지 루프 필요 없음 - 콘솔 및 서버 애플리케이션에 적합합니다.
단점
- 스레드 블로킹 - 스레드가 Sleep 동안 다른 작업을 수행할 수 없습니다.
- GUI 비응답 - 메인 스레드에서 사용하면 응답성이 저하됩니다.
3. CreateTimerQueueTimer
동작 방식: 타이머 큐를 생성하고, 스레드 풀에서 타이머 콜백을 실행합니다. 타이머 만료 시 별도의 스레드에서 콜백이 호출됩니다.
HANDLE hTimerQueue = CreateTimerQueue(); HANDLE hTimer; CreateTimerQueueTimer(&hTimer, hTimerQueue, (WAITORTIMERCALLBACK)[](PVOID lpParam, BOOLEAN TimerOrWaitFired) { SendData(); }, NULL, 0, 1000, WT_EXECUTEDEFAULT); DeleteTimerQueue(hTimerQueue);
장점
- 비동기 처리 - 스레드 풀에서 타이머 콜백이 실행됩니다.
- 정확성 높음 - GUI와 독립적으로 동작합니다.
단점
- 복잡성 - 리소스 관리와 콜백 구현이 필요합니다.
4. 비교표
항목 | SetTimer | Thread + Sleep | CreateTimerQueueTimer |
---|---|---|---|
비동기성 | O | X | O |
정확성 | 낮음 | 높음 | 높음 |
GUI 응답성 | 유지 | 저하 | 유지 |
멀티스레드 처리 | X | O | O |
결론: GUI 작업에는 SetTimer가 적합하며, 서버 및 백그라운드 작업에는 Thread + Sleep 또는 CreateTimerQueueTimer를 사용합니다.
728x90