1
0
mirror of synced 2025-11-06 03:20:55 +08:00
Files
SnowFlake-IdGenerator/C#.NET
2022-06-06 22:48:35 +08:00
..
2022-06-06 22:48:35 +08:00
2021-04-11 02:18:11 +08:00

❄ idgenerator-C#

运行环境

.NET Standard 2.0+

引用 nuget 包

<PackageReference Include="Yitter.IdGenerator" Version="1.0.*" />

调用示例C#

第1步全局 初始化(应用程序启动时执行一次):

// 创建 IdGeneratorOptions 对象,请在构造函数中输入 WorkerId
var options = new IdGeneratorOptions(1);
// options.WorkerIdBitLength = 10; // WorkerIdBitLength 默认值6支持的 WorkerId 最大值为2^6-1若 WorkerId 超过64可设置更大的 WorkerIdBitLength
// ...... 其它参数设置参考 IdGeneratorOptions 定义,一般来说,只要再设置 WorkerIdBitLength (决定 WorkerId 的最大值)。

// 保存参数(必须的操作,否则以上设置都不能生效):
YitIdHelper.SetIdGenerator(options);
// 以上初始化过程只需全局一次且必须在第2步之前设置。

第2步生成ID

// 初始化以后即可在任何需要生成ID的地方调用以下方法
var newId = YitIdHelper.NextId();

如果基于DI框架集成可以参考 YitIdHelper 去管理 IdGenerator 对象,必须使用单例模式。

事件说明

1.IIdGenerator.GenIdActionAsync 是一个可以向外部系统异步发送ID生成消息的事件它包含的消息类型有"漂移开始、漂移结束、时间回拨",具体参考 Yitter.IdGenTest 的 Program.cs 启动代码。不过订阅ID异步通知会有细微的性能损失。

2.你可在外部系统的异步async标记方法中调用本算法同步调用同样没问题。