>백엔드 개발 >Golang >Go의 Rand 패키지로 고유한 난수를 생성하는 방법은 무엇입니까?

Go의 Rand 패키지로 고유한 난수를 생성하는 방법은 무엇입니까?

DDD
DDD원래의
2024-11-06 21:06:02888검색

How to Generate Unique Random Numbers with Go's Rand Package?

Go의 Rand 패키지에서 예측 가능한 의사 난수 생성 극복

Go의 rand 패키지는 의사 난수를 생성하는 수단을 제공하지만 기본적으로 이러한 동일한 프로그램 실행에 대해 숫자가 반복될 수 있습니다. 이는 정말 무작위 결과를 찾을 때 문제가 될 수 있습니다.

문제 식별:

다음 Go 코드를 고려하세요.

package main

import (
    "fmt"
    "rand"
)

func main() {
    fmt.Println(rand.Int31n(100))
}

이 코드를 실행할 때 코드를 사용하면 매번 동일한 난수가 생성된다는 것을 알 수 있습니다. 이는 rand 패키지가 상수 시드로 의사 난수 생성기를 초기화하여 예측 가능한 결과를 얻기 때문에 발생합니다.

해결책:

모든 실행에서 고유한 난수를 보장하려면, 난수를 생성하기 전에 다른 시드를 제공해야 합니다. 일반적인 접근 방식은 현재 시간을 시드로 사용하는 것입니다.

import (
    "fmt"
    "rand"
    "time"
)

func main() {
    // Initialize the random generator with the current time in nanoseconds
    rand.Seed(time.Now().UnixNano())

    fmt.Println(rand.Int31n(100))
}

시드를 현재 시간과 같이 끊임없이 변화하는 값으로 설정하면 각 프로그램 실행에 대해 고유한 의사 난수 시퀀스를 얻을 수 있습니다.

민감한 애플리케이션을 위한 대안:

보다 안전한 난수 생성이 필요한 애플리케이션의 경우 crypto/rand 패키지 활용을 고려하세요. 이는 사용자 마우스 움직임 및 시스템 열과 같은 엔트로피 소스를 사용하여 보다 안전한 임의 값을 생성합니다. 그러나 이로 인해 성능 비용이 발생합니다.

결론:

시드를 현재 시간과 같은 동적 값으로 설정하면 예측 가능성을 극복할 수 있습니다. Go에서 rand 패키지를 실행하고 진정한 난수를 생성하세요. 이 접근 방식은 대부분의 애플리케이션에 적합하지만 보안 수준이 높은 시나리오에서는 crypto/rand 패키지를 고려해야 합니다.

위 내용은 Go의 Rand 패키지로 고유한 난수를 생성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.