编辑:
我试着在网上搜索这种行为,但到目前为止什么都没有,问题如下:
当使用以下代码时:
Random r2 = new Random(1);
for(int p = 0; p < 25; p++) {
r2 = new Random(p);
System.out.println();
for(int i = 0; i < 15; i++)
System.out.print(Math.round(r2.nextFloat()*100) + " ");
}
这将始终返回:
73 83 24 61 64 31 55 12 60 78 33 25 39 61 98
73 10 41 41 21 4 33 66 97 71 1 15 96 16 94
73 29 90 0 50 85 99 3 86 92 99 45 23 52 7
73 56 7 81 7 58 77 58 23 85 66 35 81 7 3
73 91 92 81 92 22 68 28 8 50 2 85 70 80 80
73 18 9 61 49 94 46 83 45 43 70 75 28 35 76
73 37 58 21 78 76 11 20 34 64 68 5 54 71 89
73 64 75 1 35 49 90 74 71 57 35 95 12 25 85
73 98 60 2 20 13 81 45 56 22 72 45 1 99 63
73 25 77 82 77 85 59 99 93 14 39 35 59 53 58
73 45 26 41 6 67 24 37 82 36 37 65 86 89 71
73 71 43 21 63 40 3 91 19 29 4 55 43 44 67
73 6 28 22 48 4 94 62 4 93 41 5 33 17 45
73 33 44 2 5 76 72 16 41 86 8 95 91 72 40
73 52 94 62 34 58 37 54 30 7 6 25 17 8 54
73 79 11 42 91 31 16 8 67 0 74 15 75 63 49
73 53 53 79 51 67 3 45 67 91 57 85 13 87 70
73 80 70 59 8 40 82 99 4 84 24 75 71 41 66
73 99 19 19 37 22 47 36 93 6 22 5 97 78 79
73 26 36 99 94 95 25 91 30 99 89 95 55 32 75
73 60 21 99 79 58 16 61 16 63 26 45 44 5 52
73 87 38 79 36 31 95 16 53 56 93 35 2 60 48
73 6 87 39 65 13 60 53 41 77 91 65 29 96 61
73 33 4 19 22 86 38 7 78 70 59 55 86 51 57
73 68 88 20 8 49 29 78 64 35 95 5 76 24 34
正如你所看到的,相同的数字总是几乎相同的(73=0.739…(,如果我继续使用更长的列表,类似的数字将以10或20为一组出现,这有什么原因吗?
问候,Jakes
您的问题似乎是关于具有相似种子值并返回类似第一个值的Random
。
首先:你隐藏了很多随机性,这些随机性是通过生成一个32位浮点值,然后将其减少到大约7位(你将其缩放到0-100并四舍五入(产生的。
下一篇: 类似的由于你的种子值只会变化几位(你使用的值是0到24,这不是很多位(,你会得到你期望的结果。 根据你想要实现的目标,有两种可能的解决方案: 选项#2显然不是一个真正的加密强方案(尤其是因为它还使用了固定种子(,但如果你只想";隐藏";你的随机数的非随机性,那么对于偶然的观察者来说,这可能已经足够好了。java.util.Random
不是一个加密强的RNG。它是"不可怕";从某种意义上说,但还远远不够强大。例如,它只有48位内部状态。通过设置种子,您正在设置所有该状态。由于它不是一个密码性强的RNG,因此相似的种子值可以一致地创建0
这样的"廉价"种子Random
实例initalRandom.nextLong()
为另一个Random
对象种子