基础
- 生成随机数的三种
- Math.random();
- java.util.Random伪随机数(线性同余法生成);
- java.security.SecureRandom真随机数;
Math.random 方式
- 通过random实现
java.util.Random方式
- 伪随机值
- 通过种子得到随机值,种子相同时,随机值相同
- seed 种子
- long值,可以手动通过
setSeed(seed);
方式赋值 - 默认 的seed为,一纳秒为基准,拼接一个固定值组成
- seed相同时,得到的随机数相同
- long值,可以手动通过
SecureRandom方式
- 真随机值
- 种子使用字节数据,linux下从/dev/random 或 /dev/urandom获取,可以使用-Djava.security.egd=file:/dev/urandom 来指定获取位置
- /dev/random通过系统点击事件等产生熵值;当一段时间内获取熵次数过多,会导致熵值不足而阻塞,此时,可以使用urandom,安全级别低,但不会阻塞
- 使用算法为SHA1PRNG
- 种子即使相同,也会产生不同的随机数