Java 使用 UUID 生成唯一不重复的订单编号的方法

做生成订单编号的功能。

网友指点了一下可以简单的使用 uuid 来做,但是 uuid 产生的是一个不重复的字符串。用来当做订单编号,显然不太合适。但是我们可以换个底版,来让它变成一组数字。

 

原理其实很简单,就是借助 java 中 String 类的 hashcode() 方法即可。整个代码实现如下所示:

1

2

3

4

5

6

7

8

9

10

11

public static String createOrderId() {  

    int machineId = 1;//最大支持1-9个集群机器部署  

    int hashCodeV = UUID.randomUUID().toString().hashCode();  

    if(hashCodeV < 0) {//有可能是负数  

        hashCodeV = - hashCodeV;  

    }  

    // 0 代表前面补充0       

    // 4 代表长度为4       

    // d 代表参数为正数型  

    return machineId+String.format("%015d", hashCodeV);  

}

通过对多线程的测试,结果是并发在2000左右都没有问题,可以放心的使用。

拓展:

UUID生成的字符序列是没有顺序的,这时候推荐大家使用Twitter的雪花算法,这个算法可以做的比UUID更好。根据需求来选择吧,具体的内容在这里就不列举了,上手很快的,大家自行谷歌吧。

你可能感兴趣的:(数据库,Java成长之路,精装Java)