您好,登錄后才能下訂單哦!
這篇文章主要講解了“Java雪花算法中怎么生成毫秒內的序列”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Java雪花算法中怎么生成毫秒內的序列”吧!
我們在生成時間部分獲取時間戳的時候,使用 long now = System.currentTimeMillis(); 獲取,是個毫秒級的時間戳,但是即使是這么短的時間,對于電腦來說也足夠生成很多個id,所以很多id可能會在同一個毫秒內生成,也就是時間部分的數值一樣。這個時候就要讓同一個毫秒內生成的id加上數字序列標識,就是第三部分的序列。第三部分占的長度是12位,轉成整數值就是4095,所以最后一部分的范圍就是4095到0之間的數字。如果毫秒內訪問的數量超過了這個限制怎么辦?沒法解決,只能強制等到下一毫秒再生產id。這就是第三部分的作用。
下面先定義一個序列初始值:
序列由于和時間戳有關系,所以要加載時間戳真正開始使用之前:
上面的邏輯做了判斷,同一毫秒內就讓序列加1,超過4095,就強制獲取下一毫秒的值,等時間戳不是同一毫秒的時候,序列從新開始計算。看下如何強制獲取下一毫秒:
簡單粗暴,就是while循環等下一毫秒就可以。這樣毫秒內的序列數就算獲取成功了。
我們三大部分的數字都獲取成功了,最后直接位移加合并就行:
這樣雪花算法就寫完了,下面執行一下測試:
是一個18位的long類型數字,確實是我們要的結果。等等!是不是有問題?如果此時多個線程訪問,會產生重復的id!現在的程序確實有多并發問題,需要加上鎖:
感謝各位的閱讀,以上就是“Java雪花算法中怎么生成毫秒內的序列”的內容了,經過本文的學習后,相信大家對Java雪花算法中怎么生成毫秒內的序列這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。