如何进行关于全局ID、snowflake算法的分析
发表于:2025-12-04 作者:千家信息网编辑
千家信息网最后更新 2025年12月04日,这篇文章将为大家详细讲解有关如何进行关于全局ID、snowflake算法的分析,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一开始我用的是这个简化版本
千家信息网最后更新 2025年12月04日如何进行关于全局ID、snowflake算法的分析
这篇文章将为大家详细讲解有关如何进行关于全局ID、snowflake算法的分析,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
一开始我用的是这个简化版本,后来发现有重复项。。。(demo:https://github.com/dunitian/TempCode/tree/master/2016-11-16/Twitter_Snowflake)
之后在外国大牛的基础上重写修改了部分内容(https://github.com/ccollie/snowflake-net),添加了一些注解等【支持Core】。现在是可以去Nuget直接下载使用的:Snowflake.Net
测试用例:
测试代码:
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⊙)…,举个例子:
测试代码不变的情况下,改这么一句:
完整调用demo:(https://github.com/dunitian/snowflake-net/tree/master/Demo)
core:(https://github.com/dunitian/snowflake-net/tree/master/Demo.Core)
关于如何进行关于全局ID、snowflake算法的分析就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
内容
测试
全局
算法
分析
代码
情况
文章
更多
知识
篇文章
不错
有效
任务
例子
同志
基础
外国
次数
注解
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
cf手游服务器已满正在排队中
资源数据库
辽宁服务器机柜型号
sa中怎么描述数据库
服务器机房是怎么管理的
数据库运算符-
计算机三级数据库技术备考
天津服务器迁移推荐
湖南数据库日志审计解决方案
远程服务器提示60分钟自动断开
eap软件开发
网络安全乙方具备哪些技能
行业分类与职业数据库
管理员不允许所有服务器
sci数据库文献纪录
java数据库相关软件
台州市互联网软件开发有限公司
服务器通讯异常什么原因
幻创远景网络技术
数据库安全审计平台开源
代码层面如何解决数据库隔离问题
苹果有没有连接云服务器的软件
软件开发金额多少公开招标
2020网络安全法
网络安全帽头像
自然科学一般用哪个外文数据库
centos代理服务器
2018年软件开发行业政策
上海机电网络技术特点
计算机网络技术名词