zoukankan      html  css  js  c++  java
  • Java 生成 UUID

    1.UUID 简介

       UUID 含义是通用唯一识别码 (Universally Unique Identifier),这是一个软件建构的标准。

       也是被开源软件基金会 (Open Software Foundation, OSF) 的组织应用在分布式计算环境 (Distributed Computing Environment, DCE) 领域的一部分。

       UUID 的目的,是让分布式系统中的所有元素,都能有唯一的辨识资讯,而不需要透过中央控制端来做辨识资讯的指定。

       如此一来,每个人都可以建立不与其它人冲突的 UUID。在这样的情况下,就不需考虑数据库建立时的名称重复问题。

    2.UUID 组成

       UUID保证对在同一时空中的所有机器都是唯一的。通常平台会提供生成的API。

       按照开放软件基金会(OSF)制定的标准计算,用到了以太网卡地址、纳秒级时间、芯片ID码和许多可能的数字。

    UUID由以下几部分的组合:

    (1)当前日期和时间,UUID的第一个部分与时间有关,如果你在生成一个UUID之后,过几秒又生成一个UUID,则第一个部分不同,其余相同。

    (2)时钟序列。

    (3)全局唯一的IEEE机器识别号,如果有网卡,从网卡MAC地址获得,没有网卡以其他方式获得。

       UUID的唯一缺陷在于生成的结果串会比较长。关于UUID这个标准使用最普遍的是微软的GUID(Globals Unique Identifiers)。

       标准的UUID格式为:xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx (8-4-4-4-12)。

    3.项目实战

        UUID 来作为数据库数据表主键是非常不错的选择,保证每次生成的UUID 是唯一的。
    a.生成 UUID

       public static void main(String[] args) {
            for(int i=0;i<10;i++){
                String uuid = UUID.randomUUID().toString().replaceAll("-", "");
                System.out.println(uuid);
            }
        } 

    b.生成指定数目的 UUID

        /**
         * 获得指定数目的UUID 
         * @param number int 需要获得的UUID数量 
         * @return String[] UUID数组 
         */
        public static String[] getUUID(int number){
            if(number < 1){
                return null;
            }
            String[] retArray = new String[number];
            for(int i=0;i<number;i++){
                retArray[i] = getUUID();
            }
            return retArray;
        }
    
        /**
         * 获得一个UUID 
         * @return String UUID 
         */
        public static String getUUID(){
            String uuid = UUID.randomUUID().toString();
            //去掉“-”符号 
            return uuid.replaceAll("-", "");
        }
  • 相关阅读:
    BZOJ 2073: [POI2004]PRZ [DP 状压]
    POJ 2404 Jogging Trails [DP 状压 一般图最小权完美匹配]
    BZOJ 2595: [Wc2008]游览计划 [DP 状压 斯坦纳树 spfa]【学习笔记】
    BZOJ 1226: [SDOI2009]学校食堂Dining [DP 状压]
    BZOJ 2734: [HNOI2012]集合选数 [DP 状压 转化]
    BZOJ 1097: [POI2007]旅游景点atr [DP 状压 最短路]
    BZOJ 1072: [SCOI2007]排列perm [DP 状压 排列组合]
    USACO 状压DP练习[3]
    CF781D Axel and Marston in Bitland [倍增 矩阵乘法 bitset]
    Codeforces Round #403 (Div. 2, based on Technocup 2017 Finals)
  • 原文地址:https://www.cnblogs.com/java-class/p/4727698.html
Copyright © 2011-2022 走看看