1
0
mirror of synced 2025-12-24 14:07:57 +08:00
Files
SnowFlake-IdGenerator/C#.NET
2022-08-20 14:55:35 +08:00
..
2022-07-18 18:32:30 +08:00
2022-08-20 14:55:35 +08:00

❄ idgenerator-C#

运行环境

.NET Standard 2.0+

引用 nuget 包

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

调用示例C#

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

// 创建 IdGeneratorOptions 对象,请在构造函数中输入 WorkerId
var options = new IdGeneratorOptions(Your_Worker_Id);
// 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 对象,必须使用单例模式。