질문:
Go의 rand 패키지는 다음을 제공합니다. Int31n 함수는 의사 난수를 생성하지만 반복 실행 시 동일한 출력을 생성하는 것으로 보입니다. 함수가 호출될 때마다 진정한 무작위 결과를 얻을 수 있는 방법이 있습니까?
답변:
rand 패키지는 결정적 의사 난수 생성기(PRNG)를 사용합니다. 프로그램이 실행될 때마다 PRNG는 "시드"라고 알려진 고정된 초기 값을 기반으로 동일한 일련의 숫자를 생성합니다.
실행할 때마다 다른 난수를 생성하려면 생성기를 다음과 같이 초기화하는 것이 중요합니다. 독특한 씨앗. 일반적인 접근 방식 중 하나는 프로그램이 실행될 때마다 변경되는 현재 시간을 나노초 단위로 사용하는 것입니다. 다음 코드를 사용하여 이 작업을 수행할 수 있습니다.
<code class="go">import "time" func main() { rand.Seed(time.Now().UnixNano()) fmt.Println(rand.Int31n(100)) }</code>
또는 crypto/rand 패키지는 보다 안전한 임의성 소스를 제공합니다. 마우스 움직임, 프로세서 온도, 키보드 입력 등 다양한 시스템 소스에서 엔트로피를 수집합니다. 그러나 rand 패키지에 비해 성능이 느릴 수 있습니다.
고유한 시드를 설정하거나 crypto/rand 패키지를 활용하면 rand.Int31n 함수가 호출될 때마다 진정한 난수를 생성하도록 할 수 있습니다. .
위 내용은 Go의 Rand 패키지로 진정한 난수를 생성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!