java如何生成12位永远不重复的数字

2025-04-22 16:06:22
推荐回答(4个)
回答(1):

Calendar calendar = Calendar.getInstance();

System.out.println("现在:"+calendar.getTime().getTime());

calendar.add(Calendar.YEAR, 10);

System.out.println("10年后:"+calendar.getTime().getTime());

时间戳高并发还是会有重复的,你应该每获取一次加1的方法生成。用锁对象或者把方法声明为synchronized保证并发也不会重复。如果有用数据库,也可以用数据库提供的sequence来帮你生成。

扩展资料:

当编辑并运行一个Java程序时,需要同时涉及到这四种方面。使用文字编辑软件(例如记事本、写字板、UltraEdit等)或集成开发环境(Eclipse、MyEclipse等)在Java源文件中定义不同的类;

通过调用类(这些类实现了Java API)中的方法来访问资源系统,把源文件编译生成一种二进制中间码,存储在class文件中,然后再通过运行与操作系统平台环境相对应的Java虚拟机来运行class文件,执行编译产生的字节码,调用class文件中实现的方法来满足程序的Java API调用。

参考资料来源;百度百科-Java

回答(2):

Calendar calendar = Calendar.getInstance();
System.out.println("现在:"+calendar.getTime().getTime());
calendar.add(Calendar.YEAR, 10);
System.out.println("10年后:"+calendar.getTime().getTime());

输出:

现在:1404208483914

10年后:1719827683914

如果用时间戳,截取后面12位,不要第一位,18年内都不会有大问题,不过这样的话,你的生成ID的方法就得同步,避免高并发的时候可能出现的相同ID(理论上很有可能的,虽然1毫秒内出现生成多个订单的几率很小)


建议使用yyMMdd 6位日期,加上6位增长的数字,

比如140701000001,140701000002,...

或者直接12位增长的数字,在数据库建个序列去处理就好。

回答(3):

时间戳高并发还是会有重复的,你应该每获取一次加1的方法生成。用锁对象或者把方法声明为synchronized保证并发也不会重复。如果有用数据库,也可以用数据库提供的sequence来帮你生成

回答(4):

java一级其他很多软件语言,其实是没有办法实现真正的随机问题.
截取当然会,少取以为就相当于是10毫秒级别,重复概念很大。
java应该用UUID.
或者数据库上SEQ实现