自定义生成uuid,使用JDK来实现。

生成UUID

1. UUID 简介

UUID含义是通用唯一识别码 (Universally Unique Identifier),这是一个软件建构的标准,也是被开源软件基金会 (Open Software Foundation, OSF) 的组织应用在分布式计算环境 (Distributed Computing Environment, DCE) 领域的一部分。

UUID 的目的,是让分布式系统中的所有元素,都能有唯一的辨识资讯,而不需要透过中央控制端来做辨识资讯的指定。如此一来,每个人都可以建立不与其它人冲突的 UUID。

在这样的情况下,就不需考虑数据库建立时的名称重复问题。目前最广泛应用的 UUID,即是微软的 Microsoft’s Globally Unique Identifiers (GUIDs),而其他重要的应用,则有 Linux ext2/ext3 档案系统、LUKS 加密分割区、GNOME、KDE、Mac OS X 等等。

2. UUID 组成

UUID保证对在同一时空中的所有机器都是唯一的。通常平台会提供生成的API。按照开放软件基金会(OSF)制定的标准计算,用到了以太网卡地址、纳秒级时间、芯片ID码和许多可能的数字
UUID由以下几部分的组合:
(1)当前日期和时间,UUID的第一个部分与时间有关,如果你在生成一个UUID之后,过几秒又生成一个UUID,则第一个部分不同,其余相同。
(2)时钟序列。
(3)全局唯一的IEEE机器识别号,如果有网卡,从网卡MAC地址获得,没有网卡以其他方式获得。
UUID的唯一缺陷在于生成的结果串会比较长。关于UUID这个标准使用最普遍的是微软的GUID(Globals Unique Identifiers)。
在ColdFusion中可以用CreateUUID()函数很简单地生成UUID,其格式为:xxxxxxxx-xxxx- xxxx-xxxxxxxxxxxxxxxx(8-4-4-16),其中每个 x 是 0-9 或 a-f 范围内的一个十六进制的数字。而标准的UUID格式为:xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx (8-4-4-4-12);

3. UUID的应用

使用uuid作为数据库的id组件,能保证主键不重复。

首先我们看看JDK中UUID生成策略,同时看看各种生成策略的方式的效率

public class UUIDGennerator {

    public static void main(String[] args) {
        long start = System.currentTimeMillis();
        for(int i =0 ;i<=1000000;i++) {
            String uuid = UUIDGennerator.getUUID3();
        }
        System.out.println(System.currentTimeMillis()-start);

    }

    public static String  getUUID1() {  //本机获取一百万次的,需要926ms
        String  uuidStr = UUID.randomUUID().toString();
        String uuid = uuidStr.substring(0,8)+uuidStr.substring(9,13)+uuidStr.substring(14, 18) + uuidStr.substring(19,23) + uuidStr.substring(24);
        return uuid;
    }

    public static String  getUUID2() { //本机获取一百万次 需要1250ms左右
        String  uuidStr = UUID.randomUUID().toString();
        String uuid = uuidStr.replaceAll("-", "");
        return uuid;
    }

    public static String  getUUID3() { //本机获取一百万次 需要1131ms左右
        String  uuidStr = UUID.randomUUID().toString();
        String [] uuidArray = uuidStr.split("-"); 
        StringBuilder sb = new StringBuilder();
        for(String part :uuidArray) {
            sb.append(part);
        }

        return sb.toString();
    }

    public static String  getUUID4() { //本机获取一百万次 需要1100-1150ms左右
        String  uuidStr = UUID.randomUUID().toString();
        String [] uuidArray = uuidStr.split("-"); 
        StringBuffer sb = new StringBuffer();
        for(String part :uuidArray) {
            sb.append(part);
        }
        return sb.toString();
    }
}

根据上面的测试,我们使用裁剪字符串的方式是最快的。字符串底层维护的是一个字符数组,所以使用数组下表访问是最快的。小编推荐使用字符串裁剪的方式来生成不带横杠的uuid。

有的时候,我们需要的是64位的id,那就写一个方法,两个随机的UUID拼接就好

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值