博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java 生成 UUID
阅读量:4960 次
发布时间:2019-06-12

本文共 1453 字,大约阅读时间需要 4 分钟。

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 是唯一的。

a.生成 UUID
需要用到java 自带 JDk;

 
import java.util.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

转载于:https://www.cnblogs.com/ZenoLiang/p/7631232.html

你可能感兴趣的文章
Xshell连接ESXI方法
查看>>
小白都会超详细--ELK日志管理平台搭建教程
查看>>
Leetcode 219. Contains Duplicate II
查看>>
C#_函数参数的值传递和引用传递笔记
查看>>
专业实训日志04
查看>>
Unique Paths II - LeetCode
查看>>
微信朋友圈分享链接的【图片】设置
查看>>
朱晔的互联网架构实践心得S1E2:屡试不爽的架构三马车
查看>>
2018.11.16 bzoj4827: [Hnoi2017]礼物(ntt)
查看>>
os 模块
查看>>
Perl文件句柄引用
查看>>
sqlserver资源调控期视图
查看>>
Collapsing margins
查看>>
团队项目管理:Github项目误删恢复记录
查看>>
基于mapreducer的图算法
查看>>
从SAE又回到BAE,感觉好轻松
查看>>
spring Jdbc自己主动获取主键。
查看>>
百度地图静态库的合成
查看>>
Android Fragment使用
查看>>
Codeforces Round #267 (Div. 2)D(DFS+单词hash+简单DP)
查看>>