Microsoft MVP성태의 닷넷 이야기
멀티미디어 타이머의 일정하지 않은 호출 주기에 관한 질문 [링크 복사], [링크+제목 복사],
조회: 184
글쓴 사람
압구정김선생 (ianstory00 at gmail.com)
홈페이지
첨부 파일
[Program.zip]    

안녕하세요. 멀티미디어 타이머 관련 답을 찾지 못하는 것이 있어 도움을 좀 받고자 합니다 ㅠ

그동안 .NetFramework 4.5~4.8 기반 응용프로그램에 멀티미디어 타이머를 10개 정도 생성하고, 1ms~5ms로 타이머 별로 설정하여 사용중이었습니다.

이번에 기반 프로그램에 대해 리팩토링 과정에서 기존 라이브러리들을 다시 한 번 점검하고자, 멀티미디어 타이머에 대해 분석을 했는데 조금 이상한 측정 결과가 나와서요.

1ms 설정된 타이머가 그동안은 평균 1ms에 가깝게 측정되고 있어 알지 못했는데,

이번에 min/max를 측정해보니 간헐적으로 0.010 ms까지 min이 기록되고 max는 2~5ms 까지도 측정되던데요.

Max의 경우는 다른 타이머나 쓰레드로 인해 간헐적으로 느려질 수 있다고 생각하는데, 오히려 빠르게 측정된 부분이 이상해서요.

불규칙하더라도 다른 요소에 의해 느려진다면 쉽게 이해가 가겠는데 오히려 빠르게 측정되는 부분이 이상하네요.

재현가능한 코드도 작성해보았습니다.

제가 측정이나, 사용을 잘못한걸까요?ㅠ








[최초 등록일: ]
[최종 수정일: 7/9/2025]


비밀번호

댓글 작성자
 



2025-07-10 12시37분
멀티미디어 타이머는 오차 보정을 하기 때문에 max==5ms가 걸린 경우가 있었다면 그 다음의 몇 차례에 걸쳐서는 밀린 호출을 해야 하므로 그렇게 나온 것이 아닐까... 라는 추측을 해봅니다.

Windows 자체가 RTOS는 아니기 때문에 1ms로 timer를 설정했다고 해도 원하는 만큼의 ±n 단위의 정밀도를 보장할 수는 없습니다. 스레드가 실행되는 것도 타이머 인터럽트에 따른 스케줄링이 될 때만 가능하므로 다양한 오차가 발생할 수 있을 것입니다.

그러게요, 이럴 때는 윈도우가 오픈 소스가 아니라는 점으로 인해 알아내는 데 한계가 있지 않나 싶습니다. 아마도 이것의 정확한 이유를 알고 싶다면... "Raymond Chen" 정도의 관계자에게 질문을 하셔야 할 것 같다는 생각이 드는군요. ^^
정성태

... 31  32  33  34  35  36  37  38  39  40  41  42  43  [44]  45  ...
NoWriterDateCnt.TitleFile(s)
4781질문자11/29/201617909ms워드 저장 오류 [1]
4780최진11/28/201622500안녕 하세요 빌드 관련해서 질문드립니다 꾸벅 [4]
4779손니11/28/201618831안녕하세요 질문하다 드려도 될까요 [3]
4778김상호11/25/201617934재귀호출->비재귀호출 [2]파일 다운로드1
4777권오영11/12/201620871아래 질문 상세 소스전체입니다.. [3]
4776권오영11/11/201618700제가 이클립스를 공부중인데..이상한것을 찾았습니다.. [2]
4775이성환11/11/201622468안녕하세요. SnapsToDevicePixels 질문입니다. [5]파일 다운로드1
4774popo11/10/201619015.net SSL통신 관련 질문 드립니다. [1]
4773김상호11/4/201620827재귀함수 반복문 변환 [1]파일 다운로드1
4772자연인10/27/201622126hwpctrl을 사용하는 사이트에서 나와 브라우저를 종료하면 오류메세지가 나옵니다. [1]파일 다운로드1
4771문종훈10/18/201622004.net 소스 질문이 있습니다 [2]
4770누구게~...10/15/201619289세도나 [1]
4769spow...10/13/201617666올리시는 게시물에 '좋아요'를 선택할 수 있도록 해주세요 [3]
4768브라운10/11/201619421질문 하나만 드려도 될까요 [4]
4767암호군10/4/201624883c# aes 128 암복호화 관련 문의드립니다. [3]
4766김신철9/29/201619468Visual Studio 2015에서 .net 3.5로 c# 6.0 사용시 문제점에 대해서 궁금합니다. [1]
4765spow...9/23/201618474참조를 통해 속성의 값을 변경하고 싶을 때 우아한 코딩 방법이 있을까요? [2]
4764지현명9/22/201620375Visual Studio 2008 c#에서 추가된 솔류션의 디버깅이 안걸립니다. [2]파일 다운로드1
4763송기태9/20/201618604안녕하세요! 질문이 있어 문의드립니다! [1]파일 다운로드1
4762김신철9/20/201619808Visual Studio 2015 마이그레이션 후 빌드 및 에러 문제.. 도와주세요~ [2]
4761JH9/19/201620247WPF로 Viewbox 사용 시 폰트 크기 일정화 여부 [1]
4760초보9/18/201621485유닉스서버(HP)에서 C# 서버 프로그램 실행 가능 한지요? [1]
4759dev009/16/201622953Queue out of memory [3]
4758임기성9/12/201621515MS오피스 워드 64비트에서 32비트 COM개체 사용방법 문의 [2]
4757조영준9/7/201619279DLL 후킹과 관련해서 질문이 있습니다. [2]
4756Kim ...9/6/201621305drag&drop 관련해서 문의 드립니다. [6]
... 31  32  33  34  35  36  37  38  39  40  41  42  43  [44]  45  ...