Random随机数某一时刻生成相同数问题(IBM JDK和SUN JDK差矣造成)

Random实例化会有一个seed种子,默认用系统System.currentTimeMillis().

 

public Random() { this(System.currentTimeMillis()); }

 

问题例子:编译IBM JDK 1.5和SUN JDK1.5会产生不同效果

 

 

 

当Random每次都实例新对象,然后使用r.nextInt(int),由于伪随机是特定算法根据seed来生成.所以会产生连续几个相同的数.

当Random只new一次,那r.nextInt(int)生成的伪随机,就不会出现重复问题.

 

这个问题是在Was5.1上使用Pactchca开源中RandomColorFactory碰到的问题.而在Tomcat上就不会出现.这个问题不知道为什么.

但是上述代码模拟出来的效果,与Was无异,应该不是硬件问题.而是Tomcat和Was中System.currentTimeMillis()的区别

 

有待求证.也有可能是IBM JDK和SUN JDK的区别关于System.currentTimeMillis()实现差异造成.

 

SUN JDK 结果:

>>0<<

0

26

19

>>1<<

43

20

41

>>2<<

4

36

46

>>3<<

25

28

39

IBM JDK 结果:
>>0<<
30
22
6
>>1<<
30
22
6
>>2<<
30
22
6
>>3<<
30
22
6

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值