亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何進行關于全局ID、snowflake算法的分析

發布時間:2021-12-23 17:59:18 來源:億速云 閱讀:182 作者:柒染 欄目:大數據

這篇文章將為大家詳細講解有關如何進行關于全局ID、snowflake算法的分析,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

一開始我用的是這個簡化版本,后來發現有重復項。。。(demo:https://github.com/dunitian/TempCode/tree/master/2016-11-16/Twitter_Snowflake)

如何進行關于全局ID、snowflake算法的分析

之后在外國大牛的基礎上重寫修改了部分內容(https://github.com/ccollie/snowflake-net),添加了一些注解等【支持Core】。現在是可以去Nuget直接下載使用的:Snowflake.Net

測試用例:

如何進行關于全局ID、snowflake算法的分析

測試代碼: 


using      System;    
using      System.Collections.Generic;    
using      System.Threading;    
using      System.Threading.Tasks;    
using      Snowflake.Net;    
 
namespace      Snowflake.ZConsole    
{    
          class      Program    
          {    
              private      static      int      N = 2000000;    
              private      static      HashSet<      long      >      set      =      new      HashSet<      long      >();    
              private      static      IdWorker worker =      new      IdWorker(1, 1);    
              private      static      int      taskCount = 0;    
 
              static      void      Main(      string      [] args)    
              {    
                  Task.Run(() => GetID());    
                  Task.Run(() => GetID());    
                  Task.Run(() => GetID());    
 
                  Task.Run(() => Printf());    
                  Console.ReadKey();    
              }    
 
              private      static      void      Printf()    
              {    
                  while      (taskCount != 3)    
                  {    
                      Console.WriteLine(      "..."      );    
                      Thread.Sleep(1000);    
                  }    
                  Console.WriteLine(      set      .Count == N * taskCount);    
              }    
 
              private      static      object      o =      new      object      ();    
              private      static      void      GetID()    
              {    
                  for      (      var      i = 0; i < N; i++)    
                  {    
                      var      id = worker.NextId();    
 
                      lock      (o)    
                      {    
                          if      (      set      .Contains(id))    
                          {    
                              Console.WriteLine(      "發現重復項 : {0}"      , id);    
                          }    
                          else    
                          {    
                              set      .Add(id);    
                          }    
                      }    
 
                  }    
                  Console.WriteLine($      "任務{++taskCount}完成"      );    
              }    
          }    
}    

可能有些人只關心以后怎么用?==》

IdWorker worker = new IdWorker(1, 1); //大并發的情況下,減少new的次數可以有效避免重復的可能

var id = worker.NextId();

有可能上面的減少new有些同志不太懂,(⊙o⊙)…,舉個例子:

測試代碼不變的情況下,改這么一句:

如何進行關于全局ID、snowflake算法的分析

如何進行關于全局ID、snowflake算法的分析

完整調用demo:(https://github.com/dunitian/snowflake-net/tree/master/Demo)

如何進行關于全局ID、snowflake算法的分析

 core:(https://github.com/dunitian/snowflake-net/tree/master/Demo.Core)

如何進行關于全局ID、snowflake算法的分析

關于如何進行關于全局ID、snowflake算法的分析就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

桐城市| 库车县| 安仁县| 茶陵县| 宁国市| 华池县| 河南省| 紫云| 辽源市| 改则县| 麻城市| 雷波县| 济宁市| 游戏| 杭锦后旗| 那坡县| 尼玛县| 抚松县| 榆树市| 克山县| 乌兰浩特市| 阳朔县| 昌宁县| 犍为县| 新邵县| 界首市| 罗源县| 成安县| 海南省| 天镇县| 阿图什市| 绵竹市| 景德镇市| 南昌市| 大埔区| 石渠县| 闻喜县| 高台县| 鹤岗市| 浦江县| 始兴县|