java.util.UUID存在并发问题吗

如题所述,有根据最好了,或者说在highly mutilthread env环境下,加synchronized wrapper下吗,怎么才能比较好的降低并发产生,又不大范围(如果使用这个生成随机串的次数很多,比如一天百万级别的,对于生成随机串怎么降低或者说保证唯一)影响性能.

http://stackoverflow.com/questions/7212635/is-java-util-uuid-thread-safe
http://bugs.java.com/view_bug.do?bug_id=6611830


汪汪一只猫
浏览 1401回答 2
2回答

繁星coding

这个BUG链接里面也说了在JDK1.7里面已经被Fix掉了.所以UUID目前看来在JDK1.7及以上版本都是没有并发问题的其实UUID是一中很费性能的获取唯一键的方式.在分布式环境中,建议直接用本机的Ip和自增的AtomicLong(当然可以加上随机数)来完成整个分布式的唯一键生成

慕无忌1623718

例如电商中订单号的生成,一般是预先生成某一天的订单号(预估数量,比如昨天有100W订单,今天产生100W个+一定冗余),放在memcache或者redis等缓存上,也可以放在MQ里,作为订单号池。要用,就消费订单号池里的,绝对唯一。怎么生成就视乎你业务逻辑了。一般想完全无重复,就产生0~100W的数列,再shuffle一下即可。
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Java