You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

README.md 1.3 kB

2 years ago
12345678910111213141516171819202122232425262728293031323334353637
  1. # ❄ idgenerator-C#
  2. ## 运行环境
  3. .NET Standard 2.0+
  4. (支持:.net framework4.6.1+/.net core 2.0+/.net5/.net6+/mono5.4+/Unity 2018+/Xamarin/)
  5. ## 引用 nuget 包
  6. ```
  7. <PackageReference Include="Yitter.IdGenerator" Version="1.0.*" />
  8. ```
  9. ## 调用示例(C#)
  10. 第1步,**全局** 初始化(应用程序启动时执行一次):
  11. ```
  12. // 创建 IdGeneratorOptions 对象,可在构造函数中输入 WorkerId:
  13. var options = new IdGeneratorOptions(Your_Unique_Worker_Id);
  14. // options.WorkerIdBitLength = 10; // 默认值6,限定 WorkerId 最大值为2^6-1,即默认最多支持64个节点。
  15. // options.SeqBitLength = 6; // 默认值6,限制每毫秒生成的ID个数。若生成速度超过5万个/秒,建议加大 SeqBitLength 到 10。
  16. // options.BaseTime = Your_Base_Time; // 如果要兼容老系统的雪花算法,此处应设置为老系统的BaseTime。
  17. // ...... 其它参数参考 IdGeneratorOptions 定义。
  18. // 保存参数(务必调用,否则参数设置不生效):
  19. YitIdHelper.SetIdGenerator(options);
  20. // 以上过程只需全局一次,且应在生成ID之前完成。
  21. ```
  22. 第2步,生成ID:
  23. ```
  24. // 初始化后,在任何需要生成ID的地方,调用以下方法:
  25. var newId = YitIdHelper.NextId();
  26. ```