0

0

在Java中UUID类如何生成唯一标识_Java唯一ID生成解析

P粉602998670

P粉602998670

发布时间:2026-01-19 15:32:02

|

214人浏览过

|

来源于php中文网

原创

UUID.randomUUID() 是最常用但非最优的UUID生成方式,底层用SecureRandom生成version 4随机UUID,高并发下有锁竞争、存储开销大、不可排序;适合低频单机场景,数据库主键应存为byte[16];需确定性ID时用nameUUIDFromBytes();解析字符串须校验格式;UUID不等同于Snowflake类分布式ID。

在java中uuid类如何生成唯一标识_java唯一id生成解析

UUID.randomUUID() 是最常用但不总是最优的选择

Java 的 UUID 类本身不生成 ID,它只是对 128 位值的封装和解析工具;真正生成随机 UUID 的是静态方法 UUID.randomUUID()。这个方法底层调用 SecureRandom(非伪随机),每次调用都产生一个 version 4(随机生成)的 UUID,形如 "f47ac10b-58cc-4372-a567-0e02b2c3d479"

但它不是“唯一 ID 生成器”的万能解:高并发下频繁调用 UUID.randomUUID() 可能因 SecureRandom 内部锁竞争导致延迟抖动;生成的字符串长度固定 36 字符(含连字符),存储和索引成本高于 16 字节二进制或紧凑编码;且无时间序、不可排序,不利于数据库分页或范围查询。

  • 若只需单机、低频、不关心排序的唯一标识(如消息追踪 ID、临时 token),UUID.randomUUID() 足够直接
  • 若用于数据库主键,尤其 MySQL InnoDB 表,建议转为 byte[16] 存储(去掉连字符后 hex 解码),避免字符串索引膨胀
  • 不要在循环内反复调用它生成大量 ID——可考虑复用 SecureRandom 实例并手动构造 version 4 UUID,减少锁开销

UUID.nameUUIDFromBytes() 适合基于业务数据确定性生成

当你需要“相同输入永远得到相同 UUID”,比如把用户邮箱映射为稳定 ID,或为 API 路径生成缓存 key,应使用 UUID.nameUUIDFromBytes(byte[])。它基于 MD5 哈希(RFC 4122 定义),生成的是 version 3 UUID,结果完全确定、可重现。

注意:输入字节数组不能为 null,且推荐先 UTF-8 编码再传入,否则中文等字符会出错:

立即学习Java免费学习笔记(深入)”;

PPT.AI
PPT.AI

AI PPT制作工具

下载
String input = "user@example.com";
UUID uuid = UUID.nameUUIDFromBytes(input.getBytes(StandardCharsets.UTF_8));
  • 不适用于需要“不可预测性”的场景(如密码盐、临时凭证),因为哈希可被逆向枚举
  • MD5 虽不安全,但此处仅作 determinism 用途,不影响唯一性保障
  • randomUUID() 不同,它不依赖系统熵源,无性能瓶颈

字符串解析 UUID 时必须校验格式,否则抛 IllegalArgumentException

调用 UUID.fromString(String) 解析外部传入的 UUID 字符串(如 HTTP Header、JSON 字段)前,务必确认格式合法。非法输入如缺少连字符、含非十六进制字符、长度不对,都会直接触发 IllegalArgumentException,而非返回 null。

  • 常见错误输入:"abc123""f47ac10b-58cc-4372-a567-0e02b2c3d47"(少一位)、"f47ac10b-58cc-4372-a567-0e02b2c3d47g"(含 g)
  • 生产环境建议加 try-catch 或预校验正则:^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$
  • 不要用 UUID.fromString() 解析自定义短 ID(如 Snowflake 字符串),它只认标准 UUID 格式

UUID 不等于分布式唯一 ID,别把它当 Snowflake 用

UUID 是全局唯一标识符(Globally Unique Identifier),强调“冲突概率极低”,但不保证严格单调、不保证时间局部性、不提供序列号语义。而像 Twitter Snowflake、百度 UidGenerator、美团 Leaf 这类方案,核心目标是:毫秒级时间戳 + 机器 ID + 序列号,生成 64 位 long 型递增 ID,便于数据库索引、分库分表路由、监控追踪。

  • 如果你的系统有分库分表、需要 ID 支持范围查询、要求写入性能极致,UUID(尤其是 string 形式)会成为瓶颈
  • UUID 无法反推生成时间(version 1 可以,但 Java UUID 类不支持生成 version 1)
  • 跨语言系统中,UUID 标准兼容性好;Snowflake 需统一时钟和机器 ID 分配策略,落地更重

真正容易被忽略的是:很多人把 UUID.randomUUID().toString() 当成“分布式唯一 ID”直接塞进订单表主键,却没意识到它让 MySQL 的聚簇索引彻底失效——随机字符串导致大量页分裂和磁盘随机写,压测时 QPS 断崖下跌。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

686

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

513

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

287

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

519

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

267

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

392

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

542

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

668

2023.08.14

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 850人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号