java语言中,random的是怎么实现的?
发布网友
发布时间:2022-05-10 18:41
我来回答
共2个回答
热心网友
时间:2023-10-22 11:02
看过源代码,是以System.currentMillionSeconds()为种子,然后计算出来的随机数。
看API解释
public class Randomextends Objectimplements Serializable此类的实例用于生成伪随机数流。此类使用 48 位的种子,使用线性同余公式对其进行修改(请参阅 Donald Knuth 的《The Art of Computer Programming, Volume 2》,第 3.2.1 节)。
如果用相同的种子创建两个 Random 实例,则对每个实例进行相同的方法调用序列,它们将生成并返回相同的数字序列。为了保证属性的实现,为类 Random 指定了特定的算法。为了 Java 代码的完全可移植性,Java 实现必须让类 Random 使用此处所示的所有算法。但是允许 Random 类的子类使用其他算法,只要其符合所有方法的常规协定即可。
Random 类所实现的算法使用一个 protected 实用工具方法,每次调用它都可提供最多 32 个伪随机生成的位。
热心网友
时间:2023-10-22 11:03
随机数其实不是随机的,是根据一个机器内总是变化的种子计算出来的,而机器内总是变化的我决的应该就是时间了