Microsoft MVP성태의 닷넷 이야기
stopWatch 늘어짐 문의 [링크 복사], [링크+제목 복사],
조회: 12745
글쓴 사람
차가워 (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; 정도로 아예 오버플로우가 발생하지 않게 만들어도 균일하게 나오지만 오버 플로우가 발생했을 때보다 실행 시간이 좀 더 빨라집니다.

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

... 31  32  33  34  35  36  37  38  39  40  41  42  43  [44]  45  ...
NoWriterDateCnt.TitleFile(s)
4783후배12/13/201619389MemoryStream에 관한 질문 입니다. [5]
4782김형민12/6/201618149[ C# 6.0 ] 126p 오타인가요? [6]
4781질문자11/29/201618326ms워드 저장 오류 [1]
4780최진11/28/201622905안녕 하세요 빌드 관련해서 질문드립니다 꾸벅 [4]
4779손니11/28/201619247안녕하세요 질문하다 드려도 될까요 [3]
4778김상호11/25/201618290재귀호출->비재귀호출 [2]파일 다운로드1
4777권오영11/12/201621331아래 질문 상세 소스전체입니다.. [3]
4776권오영11/11/201619124제가 이클립스를 공부중인데..이상한것을 찾았습니다.. [2]
4775이성환11/11/201622926안녕하세요. SnapsToDevicePixels 질문입니다. [5]파일 다운로드1
4774popo11/10/201619430.net SSL통신 관련 질문 드립니다. [1]
4773김상호11/4/201621092재귀함수 반복문 변환 [1]파일 다운로드1
4772자연인10/27/201622582hwpctrl을 사용하는 사이트에서 나와 브라우저를 종료하면 오류메세지가 나옵니다. [1]파일 다운로드1
4771문종훈10/18/201622368.net 소스 질문이 있습니다 [2]
4770누구게~...10/15/201619775세도나 [1]
4769spow...10/13/201617947올리시는 게시물에 '좋아요'를 선택할 수 있도록 해주세요 [3]
4768브라운10/11/201619708질문 하나만 드려도 될까요 [4]
4767암호군10/4/201625245c# aes 128 암복호화 관련 문의드립니다. [3]
4766김신철9/29/201619862Visual Studio 2015에서 .net 3.5로 c# 6.0 사용시 문제점에 대해서 궁금합니다. [1]
4765spow...9/23/201618823참조를 통해 속성의 값을 변경하고 싶을 때 우아한 코딩 방법이 있을까요? [2]
4764지현명9/22/201620769Visual Studio 2008 c#에서 추가된 솔류션의 디버깅이 안걸립니다. [2]파일 다운로드1
4763송기태9/20/201618921안녕하세요! 질문이 있어 문의드립니다! [1]파일 다운로드1
4762김신철9/20/201620107Visual Studio 2015 마이그레이션 후 빌드 및 에러 문제.. 도와주세요~ [2]
4761JH9/19/201620538WPF로 Viewbox 사용 시 폰트 크기 일정화 여부 [1]
4760초보9/18/201622014유닉스서버(HP)에서 C# 서버 프로그램 실행 가능 한지요? [1]
4759dev009/16/201623561Queue out of memory [3]
4758임기성9/12/201622023MS오피스 워드 64비트에서 32비트 COM개체 사용방법 문의 [2]
... 31  32  33  34  35  36  37  38  39  40  41  42  43  [44]  45  ...