调整XORShift生成器以返回最大范围内的数字

调整XORShift生成器以返回最大范围内的数字,第1张

调整XORShift生成器以返回最大范围内的数字

我对您的代码很有趣,并提出了以下建议:

public class XORShiftRandom {private long last;private long inc;public XORShiftRandom() {    this(System.currentTimeMillis());}public XORShiftRandom(long seed) {    this.last = seed | 1;    inc = seed;}public int nextInt(int max) {    last ^= (last << 21);    last ^= (last >>> 35);    last ^= (last << 4);    inc += 123456789123456789L;    int out = (int) ((last+inc) % max);         return (out < 0) ? -out : out;}}

我做了一个简单的测试,它是大约 倍的速度作为

java.util.Random

如果您对它的工作方式很感兴趣,可以阅读以下文章:

免责声明:

上面的代码仅用于研究目的,不能代替库存Random或SecureRandom。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5487267.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-12
下一篇 2022-12-12

发表评论

登录后才能评论

评论列表(0条)

保存