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
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
这个
BUG
链接里面也说了在JDK1.7
里面已经被Fix掉了.所以UUID
目前看来在JDK1.7
及以上版本都是没有并发问题的其实UUID是一中很费性能的获取唯一键的方式.在分布式环境中,建议直接用本机的Ip和自增的AtomicLong(当然可以加上随机数)来完成整个分布式的唯一键生成
谢邀。
例如电商中订单号的生成,一般是预先生成某一天的订单号(预估数量,比如昨天有100W订单,今天产生100W个+一定冗余),放在memcache或者redis等缓存上,也可以放在MQ里,作为订单号池。要用,就消费订单号池里的,绝对唯一。
怎么生成就视乎你业务逻辑了。一般想完全无重复,就产生0~100W的数列,再shuffle一下即可。