Java雪花算法中怎么生成毫秒内的序列

发布时间:2021-11-16 16:17:58 作者:iii
来源:亿速云 阅读:155

这篇文章主要讲解了“Java雪花算法中怎么生成毫秒内的序列”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java雪花算法中怎么生成毫秒内的序列”吧!

我们在生成时间部分获取时间戳的时候,使用 long now = System.currentTimeMillis(); 获取,是个毫秒级的时间戳,但是即使是这么短的时间,对于电脑来说也足够生成很多个id,所以很多id可能会在同一个毫秒内生成,也就是时间部分的数值一样。这个时候就要让同一个毫秒内生成的id加上数字序列标识,就是第三部分的序列。第三部分占的长度是12位,转成整数值就是4095,所以最后一部分的范围就是4095到0之间的数字。如果毫秒内访问的数量超过了这个限制怎么办?没法解决,只能强制等到下一毫秒再生产id。这就是第三部分的作用。

下面先定义一个序列初始值:

Java雪花算法中怎么生成毫秒内的序列

序列由于和时间戳有关系,所以要加载时间戳真正开始使用之前:

Java雪花算法中怎么生成毫秒内的序列

上面的逻辑做了判断,同一毫秒内就让序列加1,超过4095,就强制获取下一毫秒的值,等时间戳不是同一毫秒的时候,序列从新开始计算。看下如何强制获取下一毫秒:

Java雪花算法中怎么生成毫秒内的序列

简单粗暴,就是while循环等下一毫秒就可以。这样毫秒内的序列数就算获取成功了。

我们三大部分的数字都获取成功了,最后直接位移加合并就行:

Java雪花算法中怎么生成毫秒内的序列

这样雪花算法就写完了,下面执行一下测试:

Java雪花算法中怎么生成毫秒内的序列

是一个18位的long类型数字,确实是我们要的结果。等等!是不是有问题?如果此时多个线程访问,会产生重复的id!现在的程序确实有多并发问题,需要加上锁:

Java雪花算法中怎么生成毫秒内的序列

感谢各位的阅读,以上就是“Java雪花算法中怎么生成毫秒内的序列”的内容了,经过本文的学习后,相信大家对Java雪花算法中怎么生成毫秒内的序列这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

推荐阅读:
  1. 雪花算法(03)生成时间
  2. 雪花算法(02)算法中的位运算

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

java

上一篇:Windows2000下如何整合Mysql4.0.13与Tomcat4.1.24搭建Jsp环境

下一篇:怎么浅谈MySQL优化

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》