如题所述,有根据最好了,或者说在highly mutilthread env环境下,加synchronized wrapper下吗,怎么才能比较好的降低并发产生,又不大范围(如果使用这个生成随机串的次数很多,比如一天百万级别的,对于生成随机串怎么降低或者说保证唯一)影响性能.http://stackoverflow.com/questions/7212635/is-java-util-uuid-thread-safehttp://bugs.java.com/view_bug.do?bug_id=6611830
2 回答
繁星coding
TA贡献1797条经验 获得超4个赞
这个
BUG
链接里面也说了在JDK1.7
里面已经被Fix掉了.所以UUID
目前看来在JDK1.7
及以上版本都是没有并发问题的其实UUID是一中很费性能的获取唯一键的方式.在分布式环境中,建议直接用本机的Ip和自增的AtomicLong(当然可以加上随机数)来完成整个分布式的唯一键生成
慕无忌1623718
TA贡献1744条经验 获得超4个赞
例如电商中订单号的生成,一般是预先生成某一天的订单号(预估数量,比如昨天有100W订单,今天产生100W个+一定冗余),放在memcache或者redis等缓存上,也可以放在MQ里,作为订单号池。要用,就消费订单号池里的,绝对唯一。
怎么生成就视乎你业务逻辑了。一般想完全无重复,就产生0~100W的数列,再shuffle一下即可。
添加回答
举报
0/150
提交
取消