UUID是128位全局唯一标识符,Java通过UUID.randomUUID()生成基于随机数的版本4 UUID,利用SecureRandom确保低碰撞概率,适用于分布式系统中的会话ID、任务ID等场景;不同版本包括基于时间的V1、MD5的V3、随机的V4和SHA-1的V5,Java原生支持V3和V4,其他需第三方库;使用时需注意极小冲突概率、字符串长度较长、无序性影响数据库性能及V1可能泄露MAC地址等问题,但日常使用randomUUID()已足够安全可靠。

Java 中的 UUID 类通过特定算法生成全局唯一的标识符,不需要依赖中央机构或数据库来保证唯一性。它利用时间、硬件信息和随机数等组合方式,确保在分布式系统中也能避免重复。
UUID 是什么
UUID(Universally Unique Identifier)是一个 128 位的值,通常表示为 32 个十六进制字符,分为五段,形式如:550e8400-e29b-41d4-a716-446655440000。Java 提供了 java.util.UUID 类用于生成和操作 UUID。
如何使用 UUID.randomUUID() 生成唯一 ID
最常用的方式是调用静态方法 UUID.randomUUID(),它返回一个版本 4 的 UUID(基于随机数):
- 该方法内部使用强随机数生成器(SecureRandom)产生数据
- 生成的 UUID 包含足够的熵,碰撞概率极低
- 适用于大多数场景,如会话 ID、临时文件名、分布式任务 ID 等
示例代码:
立即学习“Java免费学习笔记(深入)”;
UUID id = UUID.randomUUID();
System.out.println(id);
不同版本的 UUID 生成机制
UUID 支持多种版本,对应不同的生成策略:
- 版本 1(Time-based):结合时间戳和机器 MAC 地址,能保证时空唯一性,但暴露硬件信息
- 版本 3(MD5 哈希):基于命名空间和名称的 MD5 哈希,相同输入总是生成相同结果
- 版本 4(Random):由随机或伪随机数生成,当前 randomUUID() 使用的就是此版本
- 版本 5(SHA-1 哈希):类似 V3,但使用 SHA-1,更安全
Java 标准库只直接支持 V3 和 V4。若需 V1 或 V5,可借助第三方库如 com.fasterxml.uuid。
UUID 的注意事项
虽然 UUID 几乎唯一,但仍需注意以下几点:
- 不能完全排除冲突可能,只是概率极小(V4 冲突概率接近 2^61 才有一例)
- 字符串形式较长,不适合做短链接主键
- 无序性可能导致数据库插入性能下降(相比自增 ID)
- 安全性要求高的场景应确认是否泄露信息(如 V1 含 MAC 地址)
基本上就这些。日常开发中使用 UUID.randomUUID() 已足够安全可靠,无需额外实现逻辑。不复杂但容易忽略的是理解其背后的生成原理,以便在特殊场景下做出合适选择。










