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

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

... 16  17  18  19  20  21  22  23  24  25  26  27  28  29  [30]  ...
NoWriterDateCnt.TitleFile(s)
5130노인코래방2/25/201910812C#에서 가장 좋은 성능을 보이는 파일 읽고 쓰는 방법이 무엇인가요? [2]
5129진우2/23/201910255닷넷 32비트 기반에서 메모리 부족으로 프로그램이 죽는경우 문의 [2]
5128게스트2/23/20197943안녕하세요. 초보개발자입니다. [3]파일 다운로드1
5127c#2/20/20196986책에 예제 문의드립니다. [2]
5125게스트2/19/20197069delegate를 활용한 event 를 적절히 불러오고 싶습니다. [2]
5124정근화2/12/20196941윈도우 서버2003 환경 오류 [2]
5123김주현2/8/20196990MS LUIS 에 대한 소개 하실 계획이 있으신가요? [1]
5122jaka...2/1/20198849Clickonce 배포 후 Command 실행 [2]파일 다운로드1
5121엔벌이1/31/20198300C# DataGridView의 MDB파일 함수? ArrayList? [1]파일 다운로드1
5120임우진1/30/20198826웹에서 응용프로그램 바로 실행하기 관련 브라우저에서 파라미터가 넘어오지 않습니다.ㅜㅜ [2]
5119guest1/29/201910206교재에 오탈자 있어 알려드리려 합니다 [1]
5118WPF꿈...1/26/20198154GetHashCode 메서드에 대해서 [1]
5117하주형1/25/20198780List<int>에 대한 이해가 잘안됩니다. [5]
5116게스트1/24/20197555asp.net 관련 gridview webform 질문 드립니다. [1]파일 다운로드1
5115Soul...1/24/20197712투명 패널 질문드립니다. [2]
5114박현일1/20/20198059WPF DataContext 관련 초보 질문을 드려봅니다.^^ [5]
5113하주형1/20/20197306안녕하세요 시작하세요 C# 인코딩관련 질문드립니다. [1]
5112손성배1/19/201916260안녕하세요 cp949 인스톨시 오류입니다... 너무 힘들어요 [5]
5111게스트1/10/20197941암호화 라이센스 관련 문의 드립니다. [1]
5110WPF꿈...1/9/20197593Thread Abort 함수 사용시 [2]
5109닷넷개발1/9/20197557thread 관련 질문 예제.. [2]파일 다운로드1
5108닷넷개발1/9/20198703thread 관련 질문 드립니다.. [4]
5107우코아1/4/201911285WPF에서 로딩중 이미지를 구현 - Project [5]파일 다운로드1
5106우코아1/3/20198933WPF에서 로딩중 이미지를 구현 - Source [1]
5104우코아1/1/201910201WPF에서 로딩중 이미지를 구현 [4]
5103이혜성12/31/20181079332bit .net 으로 만들어진 dll파일 [5]
... 16  17  18  19  20  21  22  23  24  25  26  27  28  29  [30]  ...