

新闻资讯
技术学院在Go中生成随机数需初始化随机源并选合适函数:用rand.New(rand.NewSource(time.Now().UnixNano()))创建独立实例,避免全局状态;rand.Intn(n)生成[0,n)整数,Float64()生成[0.0,1.0)浮点数,r.Read(buf)填充字节切片;非加密场景用此法,密码学安全需crypto/rand;随机字符串可结合字符集与Intn索引拼接实现。
在 Go 中使用 rand 生成随机数,关键在于正确初始化随机数生成器(避免重复种子),并根据需求选择合适的函数。默认的全局 rand.Rand 实例是线程安全但不加密安全,适合一般场景(如游戏、模拟、测试);如需密码学安全,请用 crypto/rand。
rand.Intn(n) 返回 [0, n) 区间内的随机整数(左闭右开)。注意它依赖全局随机源,首次调用前应设置种子:
rand.Seed(time.Now().UnixNano())(Go 1.20+ 已弃用,仅兼容旧代码)rand.New(rand.NewSource(time.Now().UnixNano())) 创建独立实例避免全局状态干扰,尤其在并发或单元测试中更
可控:
src := rand.NewSource(time.Now().UnixNano()) 创建种子源r := rand.New(src) 得到可复用的随机数生成器r.Intn(100) 生成 0–99 的随机整数;r.Int31n(1000) 生成 int32 范围内 0–999 的数除整数外,rand 还支持浮点数和字节切片:
r.Float32() 返回 [0.0, 1.0) 的 float32r.Float64() 返回 [0.0, 1.0) 的 float64(常用)r.Read(buf) 填充字节切片(非加密安全);如需安全随机字节,请用 crypto/rand.Read(buf)
没有内置函数,但可组合实现:
letters := "abcdefghijklmnopqrstuvwxyz"
r.Intn(len(letters)) 获取索引,拼接字符for i := range b { b[i] = letters[r.Intn(len(letters))] }
基本上就这些。记住核心原则:用独立实例、设好种子、按需选函数。不需要复杂封装,几行代码就能搞定常见随机需求。