Microsoft MVP성태의 닷넷 이야기
stopWatch 늘어짐 문의 [링크 복사], [링크+제목 복사],
조회: 12839
글쓴 사람
차가워 (chagawo1202 at naver.com)
홈페이지
첨부 파일
 

질문 글을 올릴때 부실하게 올려서 글을 다시 작성합니다.
재현 가능한 코드 없이 질문들을 남겨서 죄송합니다.

폼에는 버튼1과 리치텍스트박스1만 있습니다.
버튼을 눌러 시간 측정을 하면 할 수록
소요 시간이 조금씩 점점 늘어납니다.
cpu클럭에 따라 소요시간이 들죽날죽 달리지기는건 당연하지만
스탑워치로 시간 측정을 하면 할 수록 소요시간이 점점 불어나네요.


static Stopwatch stopwatch = new Stopwatch();
        static MyClass[] myArray = new MyClass[1_000_000];

        public class MyClass
        {
            public int cValue = 0;
        }

        public Form2()
        {
            InitializeComponent();
        }

        private void Form2_Load(object sender, EventArgs e)
        {
            for (int i = 0; i < 1_000_000; i++)
            {
                myArray[i] = new MyClass();
            }
        }

        private void button1_Click(object sender, EventArgs e)
        {
            button1.Enabled = false;

            stopwatch.Reset();
            stopwatch.Start();
            long startTick = stopwatch.ElapsedTicks;

            for (int k = 0; k < 2000; k++)
            {
                for (int i = 0; i < 1_000_000; i++)
                {
                    MyClass tmp = myArray[i];

                    if (tmp.cValue % 2 == 0)
                        tmp.cValue += 2;

                    if (tmp.cValue % 3 == 0)
                        tmp.cValue += 3;

                    if (tmp.cValue % 4 == 0)
                        tmp.cValue += 4;

                    if (tmp.cValue % 5 == 0)
                        tmp.cValue += 5;

                    if (tmp.cValue % 10 == 0)
                        tmp.cValue -= 10;

                    tmp.cValue += 1;
                    tmp.cValue += i;
                    tmp.cValue -= i;
                    tmp.cValue *= i;
                    if (tmp.cValue != 0)
                        tmp.cValue /= i;
                }
            }

            long endTick = stopwatch.ElapsedTicks;
            stopwatch.Stop();
            long ctime = endTick - startTick;
            richTextBox1.Text += string.Format("소요시간 {0:#,#}", ctime) + Environment.NewLine;

            button1.Enabled = true;
        }








[최초 등록일: ]
[최종 수정일: 2/19/2022]


비밀번호

댓글 작성자
 



2022-02-19 06시06분
[차가워] 스탑워치 뿐만 아니라 모든 시간측정 방법에서 소요시간이 늘어나는 걸로 봐서 시간측정이 아닌 다른 문제 같아 보이네요
[guest]
2022-02-19 07시14분
[차가워] 오버플로어가 일아나면 점점 실행시간이 느려지는거 같기도 한데요
[guest]
2022-02-19 09시44분
@차가워 말씀하신 오버플로우 문제가 맞는 것 같습니다. for 루프의 후반으로 갈수록 오버플로우 발생이 증가해 균일하게 발생하는 지점까지 실행 시간이 늘어나는 듯합니다. 그래서 아예 오버플로우가 항상 발생하도록 for i 루프의 초기에 tmp.cValue = int.MaxValue를 넣어 두면 실행 시간이 균일하게 나옵니다. 반면 tmp.cValue = 1000; 정도로 아예 오버플로우가 발생하지 않게 만들어도 균일하게 나오지만 오버 플로우가 발생했을 때보다 실행 시간이 좀 더 빨라집니다.

재미있는 테스트 결과를 얻으셨군요. ^^
정성태

... 61  62  [63]  64  65  66  67  68  69  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
1062김규덕5/12/201219634ffmpeg 관련 조언 구합니다. [2]
1061Dave5/11/201218744언제 스크린 캡쳐 하시나요? [1]
1058정재훈5/11/201220398c#으로 동영상에 로고를 삽입하는 기능을 구현중입니다. [3]
1057전남진5/1/201219287** 몇일째 고생하다가 웹 검색을 통해 알게되어 질문드립니다.. 초보 질문이긴하지만 도움 부탁드려요 [2]
1056안현수5/1/201221750listview 와 웹파싱에관해 질문드립니다 [1]파일 다운로드1
1055이성환4/30/201220022WPF FramworkElement의 이벤트를 가져오고 싶습니다. [3]
1054정웅모4/20/201218330안녕하세요 [1]
1053폭풍코딩4/19/201218974스마트클라이언트 ctrl-c 복사가 작동하지 않습니다. [1]
1052에슈리온4/17/201235502ClickOnce 배포시 클라이언트의 설치경로를 지정할 수 없나요? [1]
1051최정수4/10/201222576WCF 클라이언트 비정상 종료 관련 [1]
1050에슈리온4/6/201224733관리자 권한과 ClickOnce, 그리고 Bootstrapper문제 [6]
1049김성혁4/4/201219245스마트클라이언트 stand-alone 방식의 배포 문제.. [1]
1048C#조으다3/27/201221770어셈블리 로드 / 언로드와 관련해서.. [6]
1047김우형3/23/201219855WCF 서비스를 이용한 데이터 전송 중 Exception 문의 [1]
1044임동찬2/29/201219753웹에서 COM Exception.. [2]
1043박성준2/24/201218183Lazy<T> 의 지연객체 생성 전에 실 객체의 Attribute분석 [2]파일 다운로드1
1042이성환2/20/201218408BlockingMethod에 빠진 스레드를 즉시 죽이고 싶습니다...;ㅅ; [2]파일 다운로드1
1039김재영2/15/201218136어셈블리에 사용자마다 다른 값을 적용하여 자동 빌드 방법이 있을까요? [2]
1037윈드로니2/12/201219541WPF 관련 질문 드립니다. [2]
1035임동찬2/9/201217919XML, XSD, XMLCodeGenerator 관련 [2]
1033곽성현2/7/201218583훔..윈도우 디바이스 드라이버 관련 [1]
1030궁빈2/2/201221056msbuild를 이용한 웹게시 및 자동 Dist 방법론에 대해 질문 드립니다!! [6]
1028신정환1/30/201217866기존 legacy Windows application이 WoA 환경에서 동작되지 않는 이유가 무얼까요? [2]
1026노현철1/19/201220240WPF가 XP에서 느리게 로딩되는 현상에 대해 질문드립니다. [4]
1025궁그미1/18/201221300네이버 소켓 로그인 이해가 안되는점이 있는데요 [2]
1022선무당1/11/201219170TFS 에서 공통 Assembly 공유 방법에 대해서 해결책이 없을까요? [2]
... 61  62  [63]  64  65  66  67  68  69  70  71  72  73  74  75  ...