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
## 调用示例(C)

第1步,**全局** 初始化(应用程序启动时执行一次):
12
```c
yitter's avatar
yitter 已提交
13
// 创建 IdGeneratorOptions 对象,可在构造函数中输入 WorkerId:
yitter's avatar
yitter 已提交
14
IdGeneratorOptions options = BuildIdGenOptions(Your_Unique_Worker_Id);
yitter's avatar
yitter 已提交
15 16 17 18
// 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 已提交
19

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

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

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