更短且不失高效的UUID生成算法
Java原生的UUID长度为36位,嫌长
这里自己实现了一套自己的算法,来生成较短的UUID
由雪花算法启发而来,
大致原理是利用时间戳+随机值做值,然后转换成62进制(当然这个进制数你也可以搞成更多)
有一些参数可以控制一些行为,都在注释里了
你可以自己修改digits数组,乱乱序啥的,混淆一下,随机性可能更好一些
/**
* Java 原生的UUID为36位 or 32位,太长. 这里提供一个位数较短的UUID.
* <p>
* UUID生成规则,当前时间减去'零时'的毫秒数 + N位随机数,转变成62进制的String类型.
* <p>
* 当前配置可满足30年内每毫秒10^9分之一的碰撞.
* <p>
* 实测现在长度为13位,想要更短的话可以调整下方的几个参数
*
* @author libing02 , on 11月 20, 2019.
*/
public class ShortUUID {
/**
* digits还可以扩,但是不要包含下面的SEPARATOR
* <p>
* 也可以替换一个"乱序"digits排列,最终使uuid看起来不是有序的.
* <p>
* 一旦用到生产环境,digits就不要再变动了,否则会出现重复
* <p>
*/
private static final char[] digits = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"
.toCharArray();
private static final char SEPARATOR = '_';
// 2019-11-15 17:00:00
private static final long ERA_TIME = 1573808400000L;
// UUID一次轮回的指数. 12则为大概30年左右,11则为3年左右. 13就是300年
private static final int TIME_LOOP_INDEX = 12;
// 碰撞指数.毫秒下万万分之一
private static final int COLLISION_INDEX = 99999999;
private static final boolean MIX_UP = true;
public static String randomUUID() {
long passTime = System.currentTimeMillis() - ERA_TIME;
long l = passTime;
// 反转主要是为了让uuid看起来不是递增的
// 但这也会导致出现极小概率不同时间的碰撞,所以建议优先选择不反转
if (MIX_UP) {
StringBuilder stringBuilder = new StringBuilder(String.valueOf(passTime)).reverse();
while (stringBuilder.length() < TIME_LOOP_INDEX) {
stringBuilder.append('0');
}
l = Long.parseLong(stringBuilder.substring(0, TIME_LOOP_INDEX));
}
return baseConversion(l, digits.length) + SEPARATOR +
baseConversion(RandomUtils.ranInt(COLLISION_INDEX), digits.length);
}
@Test
public void test() {
System.out.println(randomUUID());
}
/**
* 将10进制转换成任意进制,照着Long原生的进制转换写的,原生最大支持到32进制
* <p>
* 这里支持到更高进制,可以扩展digits数组实现更高
*
* @param i 十进制Long型
* @param radix 进制,[2-62]
* @return 转换后的String
*/
public static String baseConversion(long i, int radix) {
if (radix < 2 || radix > digits.length) {
radix = 10;
}
int charPos = digits.length * 2;
final int size = charPos + 1;
char[] buf = new char[size];
boolean negative = (i < 0);
if (!negative) {
i = -i;
}
while (i <= -radix) {
buf[charPos--] = digits[(int) (-(i % radix))];
i = i / radix;
}
buf[charPos] = digits[(int) (-i)];
if (negative) {
buf[--charPos] = '-';
}
return new String(buf, charPos, (size - charPos));
}
}
更短且不失高效的UUID生成算法的更多相关文章
- 一个UUID生成算法的C语言实现 --- WIN32版本 .
一个UUID生成算法的C语言实现——WIN32版本 cheungmine 2007-9-16 根据定义,UUID(Universally Unique IDentifier,也称GUID)在时 ...
- 一个UUID生成算法的C语言实现——WIN32版本
源: 一个UUID生成算法的C语言实现——WIN32版本
- UUID 生成(源代码编译)
根据定义,UUID(Universally Unique IDentifier,也称GUID)在时间和空间都是唯一的.为保证空间的唯一性,每个UUID使用了一个48位的值来记录,一般是计算机的网卡地址 ...
- 分布式全局不重复ID生成算法
分布式全局不重复ID生成算法 算法全局id唯一id 在分布式系统中经常会使用到生成全局唯一不重复ID的情况.本篇博客介绍生成的一些方法. 常见的一些方式: 1.通过DB做全局自增操作 优点:简单.高 ...
- 分布式系统的唯一id生成算法你了解吗?
在分库分表之后你必然要面对的一个问题,就是id咋生成? 因为要是一个表分成多个表之后,每个表的id都是从1开始累加自增长,那肯定不对啊. 举个例子,你的订单表拆分为了1024张订单表,每个表的id都从 ...
- ES批量索引写入时的ID自动生成算法
对bulk request的处理流程: 1.遍历所有的request,对其做一些加工,主要包括:获取routing(如果mapping里有的话).指定的timestamp(如果没有带timestamp ...
- 使用深度学习检测DGA(域名生成算法)——LSTM的输入数据本质上还是词袋模型
from:http://www.freebuf.com/articles/network/139697.html DGA(域名生成算法)是一种利用随机字符来生成C&C域名,从而逃避域名黑名单检 ...
- 美团技术分享:深度解密美团的分布式ID生成算法
本文来自美团技术团队“照东”的分享,原题<Leaf——美团点评分布式ID生成系统>,收录时有勘误.修订并重新排版,感谢原作者的分享. 1.引言 鉴于IM系统中聊天消息ID生成算法和生成策略 ...
- 如何做系列(4)-微博URL短网址生成算法原理(java版、php版实现实例)
短网址(Short URL),顾名思义就是在形式上比较短的网址.通常用的是asp或者php转向,在Web 2.0的今天,不得不说,这是一个潮流.目前已经有许多类似服务,借助短网址您可以用简短的网址替代 ...
随机推荐
- Day16_93_IO_FileInputStream_读取文件字节流read()方法(一)
读取文件字节流read()方法 * 文件字节输入流:按照字节方式读取文件 * java.io.* java.io.InputStream; java.io.FileInputStream; read( ...
- Spring Cloud Alibaba(5)---Nacos(配置中心)
Nacos(配置中心) 有关Spring Cloud Alibaba之前写过四篇文章,这篇也是在上面项目的基础上进行开发. Spring Cloud Alibaba(1)---入门篇 Spring C ...
- java面试一日一题:mysql中的自增主键
问题:请讲下mysql中的自增主键 分析:该问题主要考察对mysql中自增主键的掌握,使用场景及如何设置 回答要点: 主要从以下几点去考虑 1.什么自增主键 2.使用场景是什么: 3.innodb_a ...
- js弹窗的3种方式:alert、confirm、prompt
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 分子动力学模拟软件VMD的安装与使用
技术背景 在分子动力学模拟过程中会遇到一些拓扑结构非常复杂的分子模型,所谓的复杂不仅仅是包含众多的原子,还有各种原子之间的成键关系与成键类型等.这时候就非常能够体现一个好的可视化软件的重要性了,这里我 ...
- C++ 模板元编程简单小栗子
最近看了看模板的元编程,感觉有点意思. 一些计算可以在编译过程就能够完成,榨干编译器的最后一点资源. stl中用的全是这些玩意. 当然,这增加了编译时长. 我记得貌似有"图灵完备" ...
- 【python】Leetcode每日一题-螺旋矩阵
Leetcode每日一题-螺旋矩阵 [题目描述] 给你一个 m 行 n 列的矩阵 matrix ,请按照 顺时针螺旋顺序 ,返回矩阵中的所有元素. 示例1: 输入:matrix = [[1,2,3], ...
- 在服务器上使用 smart http 搭建 Git 服务器
前言 最近一直在写 django 网页的代码,随着代码的量越来越大,管理起来也有点复杂(当然,有在使用 git 进行代码管理).同时由于有不同的工作环境,有些工作环境对 ssh 的访问有限制,所以想到 ...
- 面向对象编程OOP
这节讲一下,什么是面向对象(Object Oriented Programming).说面向对象之前,我们不得不提的是面向过程(Process Oriented Programming),C语言就是面 ...
- LINQ之方法语法
上节讲到使用linq的查询关键字进行查询,这节讲一下linq查询的另一种方式--linq方法. 使用linq方法语法,必须要会用lambda表达式,配合lambda表达式才能体会到linq的优雅便捷. ...