【Java】UUID简介
定义
UUID是通用唯一识别码(Universally Unique Identifier)的缩写,是一种软件建构的标准,目的是让分布式系统中的所有元素,都能有唯一的辨识信息。
UUID是一个128比特的数值,这个数值可以通过一定的算法计算出来。为了提高效率,常用的UUID可缩短至16位。UUID用来识别属性类型,在所有空间和时间上被视为唯一的标识。一般来说,可以保证这个值是真正唯一的任何地方产生的任意一个UUID都不会有相同的值。
格式
xxxxxxxx—xxxx—xxxx—xxxx—xxxxxxxxxxxx
8个十六进制数—4个十六进制数—4个十六进制数—4个十六进制数—12个十六进制数
一共是32
个十六进制数,128bit
(和IPV6
数目相等)。
版本
UUID具有多个版本,每个版本的算法不同,应用范围也不同。
Version 1:基于时间的UUID
基于时间的UUID通过计算当前时间戳、随机数和机器MAC地址得到。由于在算法中使用了MAC地址,这个版本的UUID可以保证在全球范围的唯一性。但与此同时,使用MAC地址会带来安全性问题,这就是这个版本UUID受到批评的地方。如果应用只是在局域网中使用,也可以使用退化的算法,以IP地址来代替MAC地址——Java的UUID往往是这样实现的(当然也考虑了获取MAC的难度)。
Version 2:DCE安全的UUID
DCE(Distributed Computing Environment)安全的UUID和基于时间的UUID算法相同,但会把时间戳的前4位置换为POSIX的UID或GID。这个版本的UUID在实际中较少用到。
Version 3:基于名字的UUID(MD5)
基于名字的UUID通过计算名字和名字空间的MD5散列值得到。这个版本的UUID保证了:相同名字空间中不同名字生成的UUID的唯一性;不同名字空间中的UUID的唯一性;相同名字空间中相同名字的UUID重复生成是相同的。
Version 4:随机UUID
根据随机数,或者伪随机数生成UUID。这种UUID产生重复的概率是可以计算出来的,但随机的东西就像是买彩票:你指望它发财是不可能的,但狗屎运通常会在不经意中到来。
Version 5:基于名字的UUID(SHA1)
和版本3的UUID算法类似,只是散列值计算使用SHA1(Secure Hash Algorithm 1)算法。
获取UUID
UUID.randomUUID(); //最常用,Version 4 |
randomUUID()
随机获取一个UUID,有极小的概率会重复fromString()
根据一个符合UUID格式的字符串获取,不常用,我都有了还获取干嘛。nameUUIDFromBytes()
根据一个字节数组获取,一般要求给定的字节数组不重复
其他方法
UUID uuid = UUID.randomUUID(); |
uuid.toString() = c68c4ead-e494-40be-a276-d5b5ef4b2c01 |
The variant number associated with this UUID
. The variant number describes the layout of the UUID
. The variant number has the following meaning:
- 0:Reserved for NCS backward compatibility
- 2:IETF RFC 4122 (Leach-Salz), used by this class
- 6:Reserved, Microsoft Corporation backward compatibility
- 7:Reserved for future definition
剩下的看官方文档吧,反正也不常用(
UUID (Java Platform SE 8 ) (oracle.com)
参考链接
Java中的UUID简单介绍_uuid java-CSDN博客