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

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

정말 어이없게도 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)
943김기룡1/3/201117341닷넷 에러시 조치사항관련... [2]
942김기룡12/27/201012295Thread 안정성 관련 문의 드립니다. [2]
941최광욱12/20/201011981정성태님 올리신 글중에 [1]
940최광욱12/20/201013581Assembly Unloading 관련해서 [2]
939최광욱12/20/201012614IIS 로그 읽기 [1]
938날쌘돌이12/14/201012810자바로 asp.net 인증하기 [3]
935김기룡12/13/201023003c#에서 c++로 개발된 dll에 byte[] 전달 관련하여 문의 드립니다. [6]
934임동찬12/7/201011234System.Reflection.Assembly.GetTypes() 메서드에 대해 [1]
929김준호12/2/201011459안녕하세요 비주얼베이직 2005 닷넷 관련 문의입니다 [1]
928김준호11/30/201012093안녕하세요 비주얼베이직 2005 닷넷 관련 문의입니다 [1]파일 다운로드1
927임동찬11/30/201013186Windows\\Temp 폴더의 이름모를 .tmp 파일들에 대해서 [1]
926이승규11/26/201032889IP접속 시도시 ORA-12504 에러 [1]
925임동찬11/11/201011060다른 프로그램의 컨트롤 건드려보기_추가질문(2) [1]
924임동찬11/10/201011987다른 프로그램의 컨트롤 건드려보기_추가질문 [1]
923임동찬11/9/201014395다른 프로그램의 컨트롤 건드려보기 [1]
922박태근11/2/201012940html5의 shape파일 관련 [1]파일 다운로드1
921박태근11/1/201013653DataTable 의 Binary변환! [1]
920김재영10/26/201013727GAC에 등록된 어셈블리를 Visual Studio에서 참조 대화상자에 보이게 할려면 어떤 방법이 있습니까? [2]
919임동찬10/22/201012522IStream [1]
918임동찬10/21/201011822System.Runtime.InteropServices.ComTypes.IStream 관련 [1]
917한귀순10/20/201015848IIS 최초 loading 시 속도 [2]
916임동찬10/15/201012214file lock 관련 [2]
915오병태10/11/201010922바쁘신대 답변 감사드립니다. [1]
914오병태10/11/201011015감사드립니다. 염치없지만 또 한번 문의드립니다. [2]
912오병태10/11/201011224윈도우즈 인증서 관련해서 문의를 드립니다.
913정성태10/11/201014246    답변글 [답변]: 윈도우즈 인증서 관련해서 문의를 드립니다.
... 61  62  63  64  [65]  66  67  68  69  70  71  72  73  74  75  ...