Microsoft MVP성태의 닷넷 이야기
정말 황당한 경우입니다.. [링크 복사], [링크+제목 복사],
조회: 8094
글쓴 사람
김대훈
홈페이지
첨부 파일
 

너무나 황당한 일을 겪어서 질문을 드립니다...
로또를 생성해주는 메서드를 만들고
각각 출력해주는 프로그램을 만들었는데요

정말 어이없게도 CTRL+F5로 컴파일을 하면 numa 와 numb의 값이 똑같이 나옵니다
F10으로 한줄씩 실행하면 정상적으로 numa 와 numb는 다른값이 나오구요...

이런일이 있을수가 있는건지 궁금해요...
4개월 공부하면서 이런적은 처음이어서..질문드려요..



using System;

namespace lotto
{
    class Program
    {
        static void Main(string[] args)
        {
            int[] numa = CreateLottoA();
            int[] numb = CreateLottoB();

            foreach (var a in numa)
            {
                Console.WriteLine(a);
            }
            foreach (var b in numb)
            {
                Console.WriteLine(b);
            }
        }
        private static int[] CreateLottoA()
        {
            
            Random rnd = new Random();
            int[] num = new int[5];
            int number = 0;

            for (int i = 0; i < 5; i++)
            {
                number = rnd.Next(0, 46);
                if (Array.IndexOf(num, number) == -1)
                {
                    num[i] = number;
                    continue;
                }
                i--;
            }
            Array.Sort(num);
            return num;
        }
        private static int[] CreateLottoB()
        {

            Random rnd = new Random();
            int[] num = new int[5];
            int number = 0;

            for (int i = 0; i < 5; i++)
            {
                number = rnd.Next(0, 46);
                if (Array.IndexOf(num, number) == -1)
                {
                    num[i] = number;
                    continue;
                }
                i--;
            }
            Array.Sort(num);
            return num;
        }
    }
}








[최초 등록일: ]
[최종 수정일: 9/23/2019]


비밀번호

댓글 작성자
 



2019-09-23 11시34분
Random의 기본 seed 값이 Environment.TickCount이기 때문이고, Random 타입 자체가 의사 난수를 생성하는 구조이기 때문에 seed가 같으면 난수 생성 배열도 같습니다. 중간에 아래와 같이 sleep을 주면 다르게 나올 것입니다.

            int[] numa = CreateLottoA();
            Thread.Sleep(16);
            int[] numb = CreateLottoB();

왜 16인지는 다음의 글을 참고하세요.

윈도우 운영체제의 시간 함수 (1) - GetTickCount와 timeGetTime의 차이점
; http://www.sysnet.pe.kr/2/0/11063

정성태
2019-09-23 12시51분
[김대훈] 와............그래서 그런거군요 ㅎㅎㅎㅎ 답변 감사드립니다.
[guest]

... 61  62  63  64  65  [66]  67  68  69  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
913정성태10/11/201014246    답변글 [답변]: 윈도우즈 인증서 관련해서 문의를 드립니다.
911나그네.10/6/201013087안녕하세요.. openssl 관련하여...혹시.. [2]
910윤용한9/17/201012768Visual Studio 2010으로 만든 Setup 파일을 Win2000 SP4에 설치 되게 할 수 없나요? [1]
908김재영9/7/201011307솔루션에 구성된 프로젝트의 버젼만 통합할려면 어떤 방법이 있습니까?
909정성태9/7/201012721    답변글 [답변]: 솔루션에 구성된 프로젝트의 버전만 통합할려면 어떤 방법이 있습니까? [1]
906임동찬8/19/201012600디버깅 중 이해할 수 없는 상황이 [1]
904김영태8/18/201013946C# Interop 관련 질문입니다. [1]
905김영태8/19/201014989    답변글 [답변]: C# Interop 관련 질문입니다. [4]
903임동찬8/17/201010942COM 객체의 타입 변경 [1]
902임동찬8/16/201010861DISPPARAMS 관련 질문 [4]
901노력자8/11/201014636.net 2008 c# 에서 만든 com+ 는 com탭에서 사용불가..?! [3]파일 다운로드1
900박정환8/9/201012732wsHttpBinding을 WS-Addressing 없이 세팅할 수는 없을 까요? [7]
899임동찬7/30/201013237WCF heartbeat 관련 질문 [3]
898이영기7/29/201011125.NET 웹용에서 함수호출에러 [1]
897임동찬7/16/201012837Visual Studio 2008에서 DB연결 관련 문제 [1]
894최종문7/14/201011071try/finally 에 관해서 문의 드립니다.
895정성태7/15/201010973    답변글 [답변]: try/finally 에 관해서 문의 드립니다.
896최종문7/15/201012049        답변글 [답변]: [답변]: try/finally 에 관해서 문의 드립니다. [1]
893이병준 donator7/7/201013105Visual Studio 2010 에서의 Build 관련 질문 [1]
889임동찬7/6/201011403아래 887번에 대한 추가 질문
890정성태7/6/201012878    답변글 [답변]: 아래 887번에 대한 추가 질문
891임동찬7/6/201012992        답변글 [추가]: [답변]: 아래 887번에 대한 추가 질문
892정성태7/6/201010423            답변글 [답변]: [추가]: [답변]: 아래 887번에 대한 추가 질문
888김재영7/5/201010267TFS에 반드시! SQL Report랑 SharePoint(or WSS)가 붙어야 합니까? [2]
887임동찬7/2/201011068WCF sendTimeout에 관하여... [1]
886김재영6/16/201011161스레드 선언시 (Parameterized/)ThreadStart에 정의되는 메소드의 위치에 질문이 있습니다. [3]
... 61  62  63  64  65  [66]  67  68  69  70  71  72  73  74  75  ...