README.md 1.1 KB
Newer Older
yitter's avatar
yitter 已提交
1
#  ❄ idgenerator-C
Z
zhouzj 已提交
2

yitter's avatar
yitter 已提交
3
## 编译说明
Z
zhouzj 已提交
4

yitter's avatar
yitter 已提交
5
1.默认是 Linux 环境,用 CMake。
yitter's avatar
yitter 已提交
6

yitter's avatar
yitter 已提交
7
2.如果是 Windows 环境,要用 Cygwin 或 MinGW。
Z
zhouzj 已提交
8

yitter's avatar
yitter 已提交
9 10 11 12 13

## 调用示例(C)

第1步,**全局** 初始化(应用程序启动时执行一次):
```
yitter's avatar
yitter 已提交
14
// 创建 IdGeneratorOptions 对象,可在构造函数中输入 WorkerId:
yitter's avatar
yitter 已提交
15
IdGeneratorOptions options = BuildIdGenOptions(Your_Worker_Id);
yitter's avatar
yitter 已提交
16 17 18 19
// options.WorkerIdBitLength = 10; // 默认值6,限定 WorkerId 最大值为2^6-1,即默认最多支持64个节点。
// options.SeqBitLength = 6; // 默认值6,限制每毫秒生成的ID个数。若生成速度超过5万个/秒,建议加大 SeqBitLength 到 10。
// options.BaseTime = Your_Base_Time; // 如果要兼容老系统的雪花算法,此处应设置为老系统的BaseTime。
// ...... 其它参数参考 IdGeneratorOptions 定义。
yitter's avatar
yitter 已提交
20

yitter's avatar
yitter 已提交
21
// 保存参数(务必调用,否则参数设置不生效):
yitter's avatar
yitter 已提交
22
SetIdGenerator(options);
yitter's avatar
yitter 已提交
23 24

// 以上过程只需全局一次,且应在生成ID之前完成。
yitter's avatar
yitter 已提交
25 26 27 28
```

第2步,生成ID:
```
yitter's avatar
yitter 已提交
29
// 初始化后,在任何需要生成ID的地方,调用以下方法:
yitter's avatar
yitter 已提交
30 31
long newId = NextId();
```
yitter's avatar
yitter 已提交
32