Java:唯一的 10 位 ID

标签 java unique

我需要在 Java 中生成一个唯一的 10 位 ID。这些是此 ID 的限制:

  • 仅限数字
  • 最多 10 位数字
  • 每秒最多可以创建 10 个不同的 ID
  • 必须是唯一的(即使应用程序重新启动)
  • 无法在数据库中保存号码
  • 尽可能快,不要给系统增加太多延迟

目前我找到的最佳解决方案如下:

private static int inc = 0;

private static long getId(){

    long id = Long.parseLong(String.valueOf(System.currentTimeMillis())
            .substring(1,10)
            .concat(String.valueOf(inc)));
    inc = (inc+1)%10;
    return id;
}

该方案存在以下问题:

  • 如果出于任何原因需要每秒创建超过 10 个 ID,则此解决方案将不起作用。
  • 在大约 32 年内可以重复此 ID(这可能是可以接受的)

创建此 ID 的任何其他解决方案?

还有什么我没有想到的问题吗?

谢谢你的帮助,

最佳答案

这是对您的一个小改进,但应该具有弹性。

本质上,我们使用当前时间(以毫秒为单位),除非自上次 id 以来它没有计时,在这种情况下我们只返回 last + 1

private static final long LIMIT = 10000000000L;
private static long last = 0;

public static long getID() {
  // 10 digits.
  long id = System.currentTimeMillis() % LIMIT;
  if ( id <= last ) {
    id = (last + 1) % LIMIT;
  }
  return last = id;
}

事实上,它应该以相对较短的周期率管理高达每秒 1000 个。要延长循环率(但缩短分辨率),您可以使用 (System.currentTimeMillis()/10) % 10000000000L(System.currentTimeMillis()/100) % 10000000000L.

关于Java:唯一的 10 位 ID,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18227787/

相关文章:

Java:抽象类中的静态方法调用抽象非静态方法?

java - 使用标识符拆分字符串中的单词的正则表达式模式

java - Apache Avro : map uses CharSequence as key

java - 如何将 Guava HashMultmap 转换为 java.util.Map

c++ - 在指针 vector 中添加非重复值的最有效方法

mysql - 使用 group by 或 distinct 删除重复项

ruby-on-rails - 如何在多态连接表上强制唯一性?

Java 套接字 : can you send from one thread and receive on another?

postgresql - Unique Constraint 错误在 PostgreSQL 中创建表(从 MySQL 迁移)

java - 如何将重复元组列表转换为唯一元组列表?