我需要在 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/