Microsoft MVP성태의 닷넷 이야기
stopWatch 늘어짐 문의 [링크 복사], [링크+제목 복사],
조회: 15351
글쓴 사람
차가워 (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)
1063발코더5/20/201222148귀신 곡할 상황 질문입니다. [3]
1062김규덕5/12/201222372ffmpeg 관련 조언 구합니다. [2]
1061Dave5/11/201222039언제 스크린 캡쳐 하시나요? [1]
1058정재훈5/11/201223450c#으로 동영상에 로고를 삽입하는 기능을 구현중입니다. [3]
1057전남진5/1/201222275** 몇일째 고생하다가 웹 검색을 통해 알게되어 질문드립니다.. 초보 질문이긴하지만 도움 부탁드려요 [2]
1056안현수5/1/201224802listview 와 웹파싱에관해 질문드립니다 [1]파일 다운로드1
1055이성환4/30/201223148WPF FramworkElement의 이벤트를 가져오고 싶습니다. [3]
1054정웅모4/20/201220810안녕하세요 [1]
1053폭풍코딩4/19/201221588스마트클라이언트 ctrl-c 복사가 작동하지 않습니다. [1]
1052에슈리온4/17/201238264ClickOnce 배포시 클라이언트의 설치경로를 지정할 수 없나요? [1]
1051최정수4/10/201225399WCF 클라이언트 비정상 종료 관련 [1]
1050에슈리온4/6/201227342관리자 권한과 ClickOnce, 그리고 Bootstrapper문제 [6]
1049김성혁4/4/201222065스마트클라이언트 stand-alone 방식의 배포 문제.. [1]
1048C#조으다3/27/201224535어셈블리 로드 / 언로드와 관련해서.. [6]
1047김우형3/23/201222097WCF 서비스를 이용한 데이터 전송 중 Exception 문의 [1]
1044임동찬2/29/201222236웹에서 COM Exception.. [2]
1043박성준2/24/201220367Lazy<T> 의 지연객체 생성 전에 실 객체의 Attribute분석 [2]파일 다운로드1
1042이성환2/20/201220935BlockingMethod에 빠진 스레드를 즉시 죽이고 싶습니다...;ㅅ; [2]파일 다운로드1
1039김재영2/15/201220761어셈블리에 사용자마다 다른 값을 적용하여 자동 빌드 방법이 있을까요? [2]
1037윈드로니2/12/201221943WPF 관련 질문 드립니다. [2]
1035임동찬2/9/201220366XML, XSD, XMLCodeGenerator 관련 [2]
1033곽성현2/7/201221189훔..윈도우 디바이스 드라이버 관련 [1]
1030궁빈2/2/201223681msbuild를 이용한 웹게시 및 자동 Dist 방법론에 대해 질문 드립니다!! [6]
1028신정환1/30/201220235기존 legacy Windows application이 WoA 환경에서 동작되지 않는 이유가 무얼까요? [2]
1026노현철1/19/201223085WPF가 XP에서 느리게 로딩되는 현상에 대해 질문드립니다. [4]
1025궁그미1/18/201223893네이버 소켓 로그인 이해가 안되는점이 있는데요 [2]
... 61  62  [63]  64  65  66  67  68  69  70  71  72  73  74  75  ...