golang 内置能实现伪随机(math/rand)和真随机(crypto/rand)的库。

真随机和伪随机概念

先大概了解一下伪随机和真随机的概念。根据密码学原理,要想对一个“随机数”进行随机性检验有以下几个标准:

  • 统计学伪随机性 - 在给定的随机比特流样本中,1 的数量大致等于 0 的数量,也就是说,“10”“01”“00”“11” 四者数量大致相等。说人话就是:“一眼看上去是随机的”。
  • 密码学安全伪随机性 - 就是给定随机样本的一部分和随机算法,不能有效的演算出随机样本的剩余部分。
  • 真随机性 - 其定义为随机样本不可重现。

根据以上几个标准,其对应的随机数也就分为以下几类:

  • 伪随机数 - 满足第一个条件的随机数。
  • 密码学安全的伪随机数 - 同时满足前两个条件的随机数。可以通过密码学安全伪随机数生成器计算得出。
  • 真随机数 -同时满足三个条件的随机数。

golang 实现伪随机

golang 取某值范围的伪随机数实现

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
package main

import (
	"fmt"
	"math/rand"
	"time"
)

func main() {
	// 随机种子
	rand.Seed(time.Now().Unix())

	// 生成 20 个 [0, 100) 范围的伪随机数。
	for i := 0; i < 20; i++ {
		result := rand.Intn(100)
		fmt.Println(result)
	}
}

golang 真随机实现

golang 取某值范围的真随机数实现

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
package main

import (
	"crypto/rand"
	"fmt"
	"math/big"
)

func main() {
	// 生成 20 个 [0, 100) 范围的真随机数。
	for i := 0; i < 20; i++ {
		result, _ := rand.Int(rand.Reader, big.NewInt(100))
		fmt.Println(result)
	}
}

本文网址: https://golangnote.com/topic/235.html 转摘请注明来源