1
0
mirror of synced 2025-12-17 10:38:10 +08:00

auto commit

This commit is contained in:
yitter
2022-09-04 09:52:51 +08:00
parent 8c46cf00ec
commit d83269347e
5 changed files with 46 additions and 34 deletions

View File

@@ -17,22 +17,23 @@ JDK 1.8+
第1步**全局** 初始化(应用程序启动时执行一次):
```
// 创建 IdGeneratorOptions 对象,在构造函数中输入 WorkerId
// 创建 IdGeneratorOptions 对象,在构造函数中输入 WorkerId
IdGeneratorOptions options = new IdGeneratorOptions(Your_Worker_Id);
// options.WorkerIdBitLength = 10; // WorkerIdBitLength 默认值6支持的 WorkerId 最大值为2^6-1若 WorkerId 超过64可设置更大的 WorkerIdBitLength
// ...... 其它参数设置参考 IdGeneratorOptions 定义,一般来说,只要再设置 WorkerIdBitLength (决定 WorkerId 的最大值)
// options.WorkerIdBitLength = 10; // 默认值6限定 WorkerId 最大值为2^6-1即默认最多支持64个节点。
// options.SeqBitLength = 6; // 默认值6限制每毫秒生成的ID个数。若生成速度超过5万个/秒,建议加大 SeqBitLength 到 10
// options.BaseTime = Your_Base_Time; // 如果要兼容老系统的雪花算法此处应设置为老系统的BaseTime。
// ...... 其它参数参考 IdGeneratorOptions 定义。
// 保存参数(必须的操作,否则以上设置都不能生效):
YitIdHelper.setIdGenerator(options);
// 以上初始化过程只需全局一次且必须在第2步之前设置。
// 保存参数(务必调用,否则参数设置不生效):
YitIdHelper.SetIdGenerator(options);
// 以上过程只需全局一次且应在生成ID之前完成。
```
第2步生成ID
```
// 初始化后,即可在任何需要生成ID的地方调用以下方法
// 初始化后在任何需要生成ID的地方调用以下方法
long newId = YitIdHelper.nextId();
```
如果基于DI框架集成可以参考 YitIdHelper 去管理 IdGenerator 对象,须使用 **单例** 模式。