并发时uuid会重复吗

并发时uuid会重复吗

问:uuid会重复吗
  1. 答:会有几率重复,只是概率非常低,即使产生了重复,要让它在同一个地方使用的概率更小。
  2. 答:可以认为不会重复,重复的概率跟彗星撞地球差不多吧
  3. 答:重复几率就像一个盲人走在大街上被蜗牛绊倒,在摸眼镜的同时摸到一张彩票并且中了500w
问:JAVA JDK提供的一个自动生成主键 UUID.randomUUID()的方法 它永远都不会重复嘛??
  1. 答:这个是黑市中提供非常重要的一个软件的。
  2. 答:这辈子都不会重复放心用吧,全球都不会重复的。就好像这世界上不可能有完全一样的人
  3. 答:从一定意义上讲,这个UUID号称是世界级的不重复,也就是说有生之年这个ID肯定是不重复的,但也只是个相对的概念。小概率事件不可能发生。
  4. 答:就像Math里的随机数一样,它不是真正意义上的随机,可以称之为“伪随机”,因为无论如何,随机数都是通过特定算法计算出来的,如果你能确定它的算法,拿到相关参数(比如系统时间,甚至是独属于你计算机硬件的某些参数),你就可以推算某时某分某秒这台计算机将产生哪一个随机数。
    当然,这些随机数在一定时间内几乎是不会重复的。
  5. 答:我想这种方法会拿到系统时间,并在每个时间的基础上加上
    一定位数的随机值,后还可以转换成字母编号
    准确地来说,在你一个项目中重复的概率太低太低
    当然世间万物都是有破绽的
    假设时间是基础,你修改了系统时间,并进行足够数量的尝试
    这个序列仍然有可能重复的
    但是需要用到序列的方法还是变量应该没有这么多,所以说,基本不可能了
    还有一个就是也许最终会检查一次项目中已经存在的序列,唯一则用,重复则继续生产
    这样就永远不会重复了
    有帮助别忘记采纳亲!
  6. 答:关于是否重复,首先要说一下uuid生成的原理
    UUID是指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的
    UUID由以下几部分的组合:
    (1)当前日期和时间,UUID的第一个部分与时间有关,如果你在生成一个UUID之后,过几秒又生成一个UUID,则第一个部分不同,其余相同。
    (2)时钟序列。
    (3)全局唯一的IEEE机器识别号,如果有网卡,从网卡MAC地址获得,没有网卡以其他方式获得。
    通过组成可以看出,首先每台机器的mac地址是不一样的,那么如果出现重复,可能是同一时间下生成的id可能相同,不会存在不同时间内生成重复的数据
    至于说同一时间产生重复的数据,就目前来说,是不会的除非极高的高并发(如果发生了,也可以通过原子性操作避免),
    所以基本上就认为不会重复好了
问:uuid会重复吗
  1. 答:1、重复问题:
    方法很多,递增法可以,但要求必须由唯一的机器生成,否则别的机器怎么知道最新的号码;就算联网也需要有固定的机器管理这些号码;这在全世界范围内是不大可能实现的。更简单的方法是,采用统一的生成算法,并同时考虑时间和空间因素。比如:利用生成号码所用的机器的时钟和该机器的硬件序列号。
    2、数量问题:
    如果你算一下就不会有此顾虑了。
    32位16进制的序列,数量空间是:16^32 = 2^128 ≈ 10^38。
    按纳秒级的时间进行计算:1年有 (10^9)×3600×24×365 ≈ 10^16 纳秒;
    设全世界有1000亿人,每人有1000台电脑:10^14(这差不多就是MAC地址的容量);
    所以:
    所有电脑一起一纳秒不停地生成不同的UUID,也够用 10^(38-16-14) = 10^8,即 1亿年的。
并发时uuid会重复吗
下载Doc文档

猜你喜欢