Go で乱数を生成する最良の方法は、アプリケーションが必要とするセキュリティのレベルによって異なります。低セキュリティ: math/rand パッケージを使用して、ほとんどのアプリケーションに適した疑似乱数を生成します。高いセキュリティ: crypto/rand パッケージを使用して、より強力なランダム性を必要とするアプリケーションに適した、暗号的に安全なランダム バイトを生成します。
Go の乱数ジェネレーターのパフォーマンス
乱数ジェネレーターは、ゲームから暗号化まで、さまざまなアプリケーションで重要です。 Go では、乱数を生成する方法がいくつかあり、それぞれに異なるパフォーマンス特性があります。
Math/Rand パッケージ
乱数を生成する最も簡単な方法は、math/rand
パッケージを使用することです。以下のメソッドが提供されます: math/rand
包。它提供了以下方法:
func Float32() float32 func Float64() float64 func Int() int func Int63() int64 func Int31() int32 func Int31n(n int32) int32 func Int63n(n int64) int64 func NormFloat64() float64 func Perm(n int) []int
这些方法使用默森旋转伪随机数发生器 (MT19937) 来生成随机数。MT19937 是一个非常快的算法,对于大多数应用程序来说已经足够快。
Crypto/Rand 包
对于需要更强随机性的应用程序,crypto/rand
包提供了以下方法:
func Read(p []byte) (n int, err error)
此方法从操作系统获取加密安全的随机字节。它比 math/rand
包中的方法慢,但它提供了更强的安全性。
实战案例
下面的程序演示了如何使用 math/rand
和 crypto/rand
包生成随机数:
package main import ( "crypto/rand" "fmt" "math/rand" "time" ) func main() { // 使用 math/rand 包生成随机数 rand.Seed(time.Now().UnixNano()) fmt.Println("Math/rand:", rand.Intn(100)) // 使用 crypto/rand 包生成随机数 var b [16]byte if _, err := rand.Read(b[:]); err != nil { fmt.Println("Error:", err) return } fmt.Println("Crypto/rand:", b) }
输出如下:
Math/rand: 23 Crypto/rand: [190 114 247 234 12 220 41 170 104 49 229 230 79 249 18 219]
请注意,crypto/rand
方法生成的字节数组是加密安全的,而 math/rand
rrreee
crypto/rand
パッケージは次のメソッドを提供します: 🎜rrreee🎜このメソッドは、オペレーティング システム Festival から暗号的に安全なランダム ワードを取得します。 。 math/rand
パッケージのメソッドよりも低速ですが、より強力な安全性が提供されます。 🎜🎜🎜実際的なケース🎜🎜🎜 次のプログラムは、math/rand
パッケージと crypto/rand
パッケージを使用して乱数を生成する方法を示しています。 🎜rrreee🎜 出力は次のとおりです。 🎜rrreee🎜 crypto/rand
メソッドによって生成されるバイト配列は暗号的に安全ですが、math/rand
メソッドによって生成される数値は単なる擬似乱数であることに注意してください。 。 🎜以上がGolang の乱数ジェネレーターのパフォーマンスはどのくらいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。