Math.random() 生成 [0,1) 内均匀分布伪随机数;正确生成整数需用 Math.floor(Math.random() * (max - min + 1)) + min,避免 round 或取模导致边界偏差。
JavaScript 中的 Math.random() 本身生成的是 [0, 1) 区间内**均匀分布**的伪随机浮点数,这是浏览器和 Node.js 环境的标准行为。只要正确使用,无需额外“确保”均匀性;真正影响均匀性的,往往是**错误的取值逻辑或范围转换方式**。
Math.random() 返回一个大于等于 0、小于 1 的伪随机数,底层基于实现相关的算法(如 xorshift 或类似 LCG 的变种),在现代引擎中已具备良好的统计均匀性和周期性。它不是密码学安全的,但对一般场景(抽奖、动画、游戏逻辑等)完全满足均匀分布要求。
常见错误是用 Math.round() 或不严谨的取整方式,导致边界概率失衡。正确做法是:
Math.floor(Math.random() * (max - min + 1)) + min
Math.floor(Math.random() * (max - min)) + min
Math.round() —— 它会让两端数值概率减半(例如 round(0.0–0.5) 都得 0,而 round(0.5–1.0) 才得 1)以下操作会破坏均匀性:
Math.floor(Math.random() * 100) % 3 → 100 不是 3 的倍数,余数 0 出现 34 次,1 和 2 各 33 次while ((r = Math.random() * 6) → 实际丢弃了大量合法值,且未修正分布
Math.random() * 10000 | 0 在极少数情况下因舍入误差略超范围(虽实际影响可忽略,但语义不清晰)若用于 Token、密钥、抽奖防篡改等场景,应改用 crypto.getRandomValues():
它由操作系统熵源提供,不可预测、无周期、统计均匀,但性能略低,非必要不替代 Math.random()。