go中生成随机数的有两个包,分别是“math/rand”(伪随机数生成器)和“crypto/rand”(用于加解密的跟安全的随机数生成器)
num1 := rand.Intn(20)
fmt.Println(num1)//第二次跟第一次生成的随机数居然是一样的!
第一次结果是: 1,第二次却还是一样的结果
初始化随机种子函数(官网seed函数)
由此可见如果不调用seed,seed就会一直是1。这就是为什么是伪随机数。
那我们用种子来试一下:
rand.Seed(100)
num2:=rand.Intn(20)
fmt.Println(num2)
运行了两次发现还是一样的数字
于是利用时间戳进行:
值得注意的是:
Unix将t表示为Unix时间,即从时间点January 1, 1970 UTC到时间点t所经过的时间(单位秒)。
在windows下,rand.Seed(time.Now().Unix())作为种子,得出的随机数是随机的
UnixNano将t表示为Unix时间,即从时间点January 1, 1970 UTC到时间点t所经过的时间(单位纳秒)。如果纳秒为单位的unix时间超出了int64能表示的范围,结果是未定义的。注意这就意味着Time零值调用UnixNano方法的话,结果是未定义的。
在windows下,rand.Seed(time.Now().UnixNano())作为种子,在高并发下得出的随机数并不随机
代码如下:
t1:=time.Now()
fmt.Println(t1)
fmt.Printf("%T\n",t1)
fmt.Println(t1.Unix())//秒
timeStamp2:=t1.UnixNano()
fmt.Println(timeStamp2)
总结一下用时间戳生成的随机数:
//step1:设置种子数,可以设置成时间戳
rand.Seed(time.Now().UnixNano())
for i:=0;i<10;i++{
//step2:调用生成随机数的函数
fmt.Println("-->",rand.Intn(100))
}
或者我们可以使用rand.NewSource(),代码如下:
source :=rand.New(rand.NewSource(time.Now().Unix()))
i:=source.Intn(12)
fmt.Println(i)