Microsoft MVP성태의 닷넷 이야기
멀티미디어 타이머의 일정하지 않은 호출 주기에 관한 질문 [링크 복사], [링크+제목 복사],
조회: 45
글쓴 사람
압구정김선생 (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" 정도의 관계자에게 질문을 하셔야 할 것 같다는 생각이 드는군요. ^^
정성태

1  2  3  4  5  6  7  8  9  10  11  [12]  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5683김민혁7/1/202213583HttpWebRequest POST 전송 관련해서 질문 드립니다. [4]파일 다운로드1
5682김기헌6/20/202212266안녕하세요 서로 다른 스레드에서 동일 인스턴스의 메소드를 호출할때 질문드립니다 [2]
5681미래는투...6/19/202212534VC++ 빌드 관련 문의 (h파일이 바뀌었는데 컴파일을 꼭 하지 않아도 되나요?) [1]
5680Syong6/12/202213631EXE파일에 속성값 추가하는 방법이 있나요? [2]파일 다운로드1
5679차가워6/8/202213058tcpip socket 여러 랜카드 사용 시 연결 문의 [1]
5678차가워6/7/202212965원자적 실행 문의 [3]
5677장성욱6/7/202212725블루투스 포트와 시리얼포트 연결시 에러 [2]
5675차가워5/29/202213746윈도우설정 프로세스사용계획 옵션과 c# 스레드 [1]
5674민우5/29/202214028C++ 의 RTTI, Reflection 으로 객체 멤버변수, 멤버함수 목록 추출 문의 [2]
5673조은현5/25/202214177안녕하세요 선생님! c#에서 TCP/IP의 keep alive 기능의 사용법에 대해서 질문드리고 싶어요! [2]파일 다운로드2
5672game...5/23/202214200안녕하세요 GC를 일시적으로 중단시키는 방법이 있을까요? [5]
5671한예지 donator5/20/202215138델리게이트와 함수포인터 선언 시, 차이점 질문 있습니다. [3]
5670유필재5/20/202215666c#에서 현재프로그램에서 사용한 인터넷사용량 측정이 가능한가요? [3]
5669한예지 donator5/19/202213835이벤트 접근 제한자 질문 있습니다. [2]
5667ocm5/14/202212688c# 콜백 메서드 [2]
5666김호영5/13/202212622c# winform에서 svg 이미지 사용 [1]
5665장성욱5/11/202212386C# 타이머 관련 질문 [5]
5664차가워5/11/202213587아스키로 구성된 바이트를 long으로 변환 문의 [1]
5663김석규5/11/202213234VSTO를 이용해 엑셀데이터를 저장할때, 최종 입력값을 인식하지 못합니다. [2]
5662한예지 donator5/10/202211772혹시 사이트 회원가입은 어떻게 하는 것인가요? [1]
5661한예지 donator5/10/202211443for문 안에 await가 있는 경우 질문드립니다. [3]
5660tky5/10/202212146특정 작업을 멀티스레딩으로 처리 할 경우 어떤 방법이 가장 효율적일까요? [2]
5659한예지 donator5/9/202212408Task, TaskAwaiter 질문 있습니다. [3]
5658한예지 donator5/9/202213716교재 689, 690쪽(async/await) 질문입니다. [5]
5657C#초보5/8/202212247초보 단순 질문 입니다.,ㅠ [1]
5656부탁드립...5/6/20221445432bit dll 을 64bit dll 화 [2]
1  2  3  4  5  6  7  8  9  10  11  [12]  13  14  15  ...