编辑:
我尝试在网络上搜索此行为,但到目前为止没有任何结果,问题如下:
当使用以下代码时:
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) + " ");
}
Run Code Online (Sandbox Code Playgroud)
这总是会返回:
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
Run Code Online (Sandbox Code Playgroud)
正如你所看到的,相同的数字总是几乎相同(73 = 0.739...),如果我继续使用更长的列表,相似的数字将出现在 10 或 20 组中,这是否有任何原因发生?
问候,杰克斯
看来您的问题是关于Random相似的种子值返回相似的第一个值。
首先:您隐藏了通过生成 32 位浮点然后将其减少到大约 7 位(将其缩放到 0-100 并四舍五入)而产生的大量随机性。
Next:java.util.Random不是一个加密强度高的 RNG。从某种意义上说,它“并不可怕”,但还远谈不上强大。例如,它只有 48 位内部状态。通过设置种子,您就设置了所有该状态。由于它不是密码学上强大的 RNG,因此相似的种子值可以一致地创建相似的输出值。
由于您的种子值仅变化几个位(您使用 0 到 24 的值,这不是很多位),因此您会得到预期的结果。
根据您想要实现的具体目标,有两种可能的解决方案:
0Random从中创建一个初始实例。Random的“真实”种子。RandominitalRandom.nextLong()选项 #2 显然不是一个真正的加密强方案(尤其是因为它也使用固定种子),但如果您只想“隐藏”随机数的非随机性,那么对于临时观察者来说它可能已经足够好了。
| 归档时间: |
|
| 查看次数: |
226 次 |
| 最近记录: |