在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 还支持浮点数和字节切片:
立即学习“go语言免费学习笔记(深入)”;
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))] }
基本上就这些。记住核心原则:用独立实例、设好种子、按需选函数。不需要复杂封装,几行代码就能搞定常见随机需求。
以上就是如何在Golang中使用rand生成随机数_Golang rand随机数生成示例的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号