Microsoft MVP성태의 닷넷 이야기
stopWatch 늘어짐 문의 [링크 복사], [링크+제목 복사],
조회: 12843
글쓴 사람
차가워 (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)
864장근배2/1/201017925    답변글 [답변]: AppPolId를 알 수 있는 방법이 있는지요?
858생초보1/26/201018360안녕하세요.. 파일 생성 처리 문제로 .... [2]
857꼭지1/22/201024827How to support Basic + Windows authentication mode in WCF(RESTful service) [4]파일 다운로드2
856질의자1/13/201022073vcredist_x86 배포 관련 여쭙습니다. [1]
855임동찬1/13/201020814이벤트 핸들러와 쓰레드의 관계 2 [4]파일 다운로드2
854임동찬1/12/201020747이벤트 핸들러와 쓰레드의 관계 [1]
853장근배1/12/201019861압축 프로그램,, [1]
852임동찬1/6/201017138base.OnStart(agrs) [1]
851한귀순1/6/201022615oracle & transaction 질문 [5]
850박한주12/31/200919751COM과 C#간 권한 문제에 관해 여쭤봅니다. [5]
848날쌘돌이12/22/200920727C#으로 개발하는 ActiveX 디버깅 문제 [5]
847최승문12/16/200919501winform에서 웹서비스를 이용할때, 객체가 전송안되는 문제... [2]
846이강구12/14/200918462ATL COM 제작 문의 [3]
845김재영12/9/200921273ClickOnce에서 WinForm을 배포시 변동되는 Args값을 넘길 수 있나요? [3]파일 다운로드1
843김재영12/2/200918848Hyper-V 사용에 대해여 질문이 있습니다. [2]
842한귀순12/1/200921645Attempted to read or write protected memory [2]
841장근배11/30/200923452첨부 파일 Download시 한글 Name [2]
844장근배12/3/200917920    답변글 [답변]: 첨부 파일 Download시 한글 Name파일 다운로드1
840박영민11/20/200917851웹 애플리케이션 질문입니다. [1]
837left...10/21/200918534아래 게시글 관련하여 추가 질문 [3]
836left...10/19/200919515ActiveX 상에서 암시적 dll 로드 [1]
832김우진10/15/200916013C# 에서 swa + security 구현 방법이 없을까요?
833정성태10/15/200920415    답변글 [답변]: C#에서 swa + security 구현 방법이 없을까요? [1]
834김우진10/15/200916290        답변글 예제 메시지 올려드릴께요. [2]파일 다운로드1
838이영우10/30/200916201            답변글 국세청 전자세금계선서에 관하여 문의드립니다.
831채승수10/13/200918213스마트 클라이언트 GAC 등록 문제 여쭤봅니다... [2]
... 61  62  63  64  65  66  67  68  [69]  70  71  72  73  74  75  ...