Random伪随机数

Random类的实例用于生成伪随机数流。此类使用 48 位的种子,使用线性同余公式 (linear congruential form) 对其进行了修改(请参阅 Donald Knuth 的The Art of Computer Programming, Volume 3,第 3.2.1 节)。

如果用相同的种子创建两个 Random 实例,则对每个实例进行相同的方法调用序列,它们将生成并返回相同的数字序列。为了保证此属性的实现,为类 Random 指定了特定的算法。为了 Java 代码的完全可移植性,Java 实现必须让类 Random 使用此处所示的所有算法。但是允许 Random 类的子类使用其他算法,只要其符合所有方法的常规协定即可。

Random 类实现的算法使用一个 protected 实用工具方法,每次调用它最多可提供 32 个伪随机生成的位。 


如果用相同的种子创建两个 Random 实例,则对每个实例进行相同的方法调用序列

当我们设置了种子数为2时,生成的随机数

 public static void rundom() {
        Random a = new Random();
        a.setSeed(2);
        int i = 5;
        while (i >0) {
            print(9, a.nextInt(100));
            i--;
        }
    }

将会始终是

[9],8

[9],72

[9],40
[9],67
[9],89

猜你喜欢

转载自blog.csdn.net/qq_32097871/article/details/79645821