Java:唯一的10位数ID

mag*_*iez 13 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;
}
Run Code Online (Sandbox Code Playgroud)

该解决方案存在以下问题:

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

是否有其他解决方案来创建此ID?

我没想到的任何其他问题?

谢谢你的帮助,

Old*_*eon 9

这是对你的一个小小的改进,但应该是有弹性的.

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;
}
Run Code Online (Sandbox Code Playgroud)

因为它应该以相对较短的循环速率管理高达每秒1000次.要延长循环速率(但缩短分辨率),您可以使用(System.currentTimeMillis() / 10) % 10000000000L(System.currentTimeMillis() / 100) % 10000000000L.

  • 将它设置为线程安全也许是一个好主意. (2认同)