Microsoft MVP성태의 닷넷 이야기
실행 환경에 따른 Thread.Sleep 딜레이 차이 질문 [링크 복사], [링크+제목 복사]
조회: 5570
글쓴 사람
heroho
홈페이지
첨부 파일
 

안녕하세요 .

Thread.Sleep 함수 관련 질문드립니다.


  -- 아래의 소스는 버튼을 눌렀을때 패널이 지정된 위치까지 좌측 또는 우측으로 움직이는 스레드를 구현한 내용입니다.
     그런데 개발용 PC 에서는 SlidPanel이 약 1초만에 움직였다면 , 테스트용 PC에서는 약 4초의 시간이 걸립니다. (테스트용 PC가 성능은 더 좋은 상태)
     TickCount 계산을 통한 Delta time 으로 차이를 구현해보려 했으나 , 두 PC 환경에서 스레드 Tick간 차이는 동일

 private void move()
        {
            while (Moving)
            {
                SlidePanel.BeginInvoke(new Action(() =>
                {
                    if (SlideDirection == 0) // Left
                    {
                        SlidePanel.Left -= 4;
                        if (SlidePanel.Left <= SystemSettingbtn.Left)
                        {
                            SlidePanel.Left = SystemSettingbtn.Left;

                            SystemPanel.BeginInvoke(new Action(() =>
                            {
                                SystemPanel.BringToFront();
                            }));

                            Moving = false;
                        }
                    }
                    else // Right
                    {
                        SlidePanel.Left += 4;
                        if (SlidePanel.Left >= EnvSettingbtn.Left)
                        {
                            SlidePanel.Left = EnvSettingbtn.Left;

                            EnvironmnetPanel.BeginInvoke(new Action(() =>
                            {
                                EnvironmnetPanel.BringToFront();
                            }));

                            Moving = false;
                        }
                    }
                }));

                Thread.Sleep(1);
            }
        }





--- > await Task.Delay(1) 를 이용하면 두 PC환경에서 동일 한 시간이 걸리는 것을 확인 했지만
      Thread.Sleep(1)이 더 좋은 환경에서 느려지는게 좀 이해가 안됩니다.








[최초 등록일: ]
[최종 수정일: 2/4/2021]


비밀번호

댓글 작성자
 



2021-02-04 03시46분
재미있는 문제군요, 딱 위의 예제 코드만을 기반으로 한 재현 가능한 프로젝트를 올려주시겠어요?
정성태
2021-02-04 06시05분
[heroho] 하루 고생해서 문제의 원인을 찾았네요.
CPU CLOCK 의 차이였습니다.

개발용 PC - i5-7600 3.5GHZ (4Core)
테스트 PC - i5-8500 3.0GHZ (6Core)

단순히 클럭이 높다고 좋다고 하기도 뭐하고 코어가 많다고 좋다고 하기 뭐하지만
다른 과부화 없이 간단한 기능 스레드여서 클럭의 영향이었던것 같습니다.

개발 말고 주변 기기 공부도 해야겠네요...
[guest]
2021-02-04 07시14분
애매하군요, 일단 그 소스만 봐서는 3.5/3.0GHz 사이의 성능 차이가 4배나 난다는 것은 설명이 안 됩니다. (게다가 요즘은 Turbo Boost와 같은 기능이 있어서 필요하다면 base speed 이상의 클럭이 동작할 수 있으므로 기준 클럭이 꼭 신뢰할 수 있는 것은 아닙니다.) 그보다는, 가령 보안 프로그램이 설치되어 있다던가... 윈도우 메시지 후킹 관련한 모듈이 더 설치되었다거나... 하는 등의 뭔가 환경 상의 차이를 의심해 보는 것이 좋겠습니다.

일단, 제가 가지고 있는 모든 PC에서는 3.4/3.6 정도만 있어서 딱히 시간차가 거의 없어 재현이 안 됩니다. (첨부하신 소스 코드 게시물은 삭제하겠습니다.)
정성태
2021-02-05 10시02분
[heroho] -- 더 찾은 내용이 있어서 공유합니다. , 저와 같은 현상을 겪는 , 겪을 분들을 위해.

내용을 더 찾아보니 C# Thread.Sleep 에 사용되는 Timer 의 기본 해상도가 15ms 라고 하는데. [다른곳에서 찾았으나 성태님도 언급을 하신적이 있더라고요]
그래서 Sleep에 Time을 1-> 20정도로 변경하니 모든 환경에서 런타임이 다 동일해졌습니다.

그리고 권장하지는 않는다고 하는데 강제적으로 타이머 해상도를 변경하는 timeBeginPeriod 함수를 사용하여 timeBeginPeriod(1) 로 설정하고
Sleep(5) 정도로 변경 후 테스트 했을떄 변경 전에는 속도 차이가 나던 것이 두 환경에서 시간 차 없이 UI 가 보여지는것 또한 확인되었습니다.

CPU Clock 성능에 따라선지 다른 외부의 조건 때문인지 정확하게는 모르겠으나 Window에서 알아서 주기를 건들이는것 같기도 합니다만.
네.. 뭐 이것도 추측이긴 하지만요.
[guest]
2021-02-05 10시04분
[heroho] 테스트 PC에서 4배정도 느려진것 같다고 느낀 속도가
Sleep(15) 정도의 속도였더라고요.
[guest]
2021-02-05 08시41분
시행착오 공유해 주셔서 감사합니다. ^^
정성태
2021-02-05 08시43분
[dd] Thread.Sleep하는 스레드의 thread priority 한번 높여보시겠어요?
[guest]
2021-02-05 08시45분
[dd] 아 1이군요 ㅋㅋㅋ 의미없겠습니다
[guest]

... 16  17  18  19  20  21  22  23  [24]  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
53154/6/20206861dll파일 로드 원리? 부분에서 도움받고싶습니다. [3]
5314강성욱3/31/20208742메서드 내에서 await 2번 등장할 때의 이해 [11]파일 다운로드1
5313강성욱3/27/20206580await 2번 [1]
53121a2a...3/20/20206348Re raw data write 질문 관련 [1]파일 다운로드1
53111a2a...3/20/20207129Raw data write 관련 질문 [1]파일 다운로드1
5310아스파넬3/15/202071671초에 5회 함수호출 제한 관련 질문입니다. [1]
5309하태3/11/20209022안녕하십니까. c# Winform UI 질문드리겠습니다! [3]파일 다운로드1
5308질문3/9/20207839Window XP SP3 32bit 환경(Window Update 모두 완료)에서 .Net Framework 4.0.3 으로 빌드된 .dll 파일 gacutil.exe 등록 관련 문의 [5]
5306개발자3/9/20206673C#을 통해 인터넷 접속 가능한 이더넷을 선택할 수 있는지요? [1]
5305JaeS...3/9/20206378RAW파일 생성 질문드립니다 [8]파일 다운로드1
5303궁금하당2/27/20208700C#에서 C++ DLL읽기 (아래 글쓴이) [1]
5302궁금하당2/27/202010811C#에서 C++ DLL호출 ('PInvokeStackImbalance') [4]파일 다운로드1
5301질문합니...2/27/20206244소켓 대량 데이터 디자인 문의 [1]
5300nals...2/27/20206891vs2013에서 BinaryFormatter Serialize 후 vs2015에서 Deserialize시 예외 발생 [3]파일 다운로드1
5298질문2/26/20208290.lic 파일에 대해 질문 있습니다. [9]
5297임한승2/26/20205870vs2013에서 BinaryFormatter Serialize 후 vs2015에서 Deserialize시 예외 발생 건 [1]파일 다운로드1
5295나그네2/25/20207289클라이언트 PC 정보 조회관련.. [2]
5294닷넷초보ㅠ2/25/20207260윈폼으로 socket통신프로그램 만든후 release로 디버깅한 실행파일을 다른컴퓨터에서 실행할때 반응이없어요 [1]
5293탱코2/21/20207177검색을 하고 싶은데 어떻게 검색을 해야 할 지 모르겠습니다. [1]
5292아부리2/19/20207083XingApiNet 관련 질문 [3]
5291지현명2/15/20207822JsonConvert.Serialize 하고 Deserialize 할때 간헐적으로 한글 깨짐 현상 문의 합니다. [3]
5290베도빈2/15/20207164직접 제작한 사용자 정의 콘트롤 DLL, 실행파일에 포함시켜 배포할 수 있을까요? [1]
5288김성배2/14/20207573c# 참조추가 기능에서 DirectX 참조가 보이지 않아요.. DircetX 11 은 설치 되어 있습니다. [1]
5287C# 초...2/14/20206581프로그램 실행 질문 드립니다. [4]파일 다운로드1
5286gongs2/3/202013938윈도우 배율 및 레이아웃에 대한 질문입니다. [3]
5285강성욱1/27/20207690작업관리자에 표시되는 스레드 개수와 프로그램 내 스레드 개수 일치 [1]
... 16  17  18  19  20  21  22  23  [24]  25  26  27  28  29  30  ...