提交 baaf1a49 编写于 作者: yitter's avatar yitter

auto commit

上级 20c6d38f
# ❄ idgenerator-C# # ❄ idgenerator-C#
## 运行环境 ## 运行环境
.NET Standard 2.0+ .NET Standard 2.0+
(支持:.net framework4.6.1+/.net core 2.0+/.net5/.net6+/mono5.4+/Unity 2018+/Xamarin/) (支持:.net framework4.6.1+/.net core 2.0+/.net5/.net6+/mono5.4+/Unity 2018+/Xamarin/)
## 引用 nuget 包 ## 引用 nuget 包
``` ```
<PackageReference Include="Yitter.IdGenerator" Version="1.0.*" /> <PackageReference Include="Yitter.IdGenerator" Version="1.0.*" />
``` ```
## 调用示例(C#) ## 调用示例(C#)
第1步,**全局** 初始化(应用程序启动时执行一次): 第1步,**全局** 初始化(应用程序启动时执行一次):
``` ```
// 创建 IdGeneratorOptions 对象,可在构造函数中输入 WorkerId: // 创建 IdGeneratorOptions 对象,可在构造函数中输入 WorkerId:
var options = new IdGeneratorOptions(Your_Unique_Worker_Id); var options = new IdGeneratorOptions(Your_Unique_Worker_Id);
// options.WorkerIdBitLength = 10; // 默认值6,限定 WorkerId 最大值为2^6-1,即默认最多支持64个节点。 // options.WorkerIdBitLength = 10; // 默认值6,限定 WorkerId 最大值为2^6-1,即默认最多支持64个节点。
// options.SeqBitLength = 6; // 默认值6,限制每毫秒生成的ID个数。若生成速度超过5万个/秒,建议加大 SeqBitLength 到 10。 // options.SeqBitLength = 6; // 默认值6,限制每毫秒生成的ID个数。若生成速度超过5万个/秒,建议加大 SeqBitLength 到 10。
// options.BaseTime = Your_Base_Time; // 如果要兼容老系统的雪花算法,此处应设置为老系统的BaseTime。 // options.BaseTime = Your_Base_Time; // 如果要兼容老系统的雪花算法,此处应设置为老系统的BaseTime。
// ...... 其它参数参考 IdGeneratorOptions 定义。 // ...... 其它参数参考 IdGeneratorOptions 定义。
// 保存参数(务必调用,否则参数设置不生效): // 保存参数(务必调用,否则参数设置不生效):
YitIdHelper.SetIdGenerator(options); YitIdHelper.SetIdGenerator(options);
// 以上过程只需全局一次,且应在生成ID之前完成。 // 以上过程只需全局一次,且应在生成ID之前完成。
``` ```
第2步,生成ID: 第2步,生成ID:
``` ```
// 初始化后,在任何需要生成ID的地方,调用以下方法: // 初始化后,在任何需要生成ID的地方,调用以下方法:
var newId = YitIdHelper.NextId(); var newId = YitIdHelper.NextId();
``` ```
Win32/ Win32/
*.exe *.exe
*.dproj.local *.dproj.local
*.identcache *.identcache
__* __*
# ❄ idgenerator-Java # ❄ idgenerator-Java
## 运行环境 ## 运行环境
JDK 1.8+ JDK 1.8+
## 引用 maven 包 ## 引用 maven 包
``` ```
<dependency> <dependency>
<groupId>com.github.yitter</groupId> <groupId>com.github.yitter</groupId>
<artifactId>yitter-idgenerator</artifactId> <artifactId>yitter-idgenerator</artifactId>
<version>1.0.6</version> <version>1.0.6</version>
</dependency> </dependency>
``` ```
## 调用示例(Java) ## 调用示例(Java)
第1步,**全局** 初始化(应用程序启动时执行一次): 第1步,**全局** 初始化(应用程序启动时执行一次):
``` ```
// 创建 IdGeneratorOptions 对象,可在构造函数中输入 WorkerId: // 创建 IdGeneratorOptions 对象,可在构造函数中输入 WorkerId:
IdGeneratorOptions options = new IdGeneratorOptions(Your_Unique_Worker_Id); IdGeneratorOptions options = new IdGeneratorOptions(Your_Unique_Worker_Id);
// options.WorkerIdBitLength = 10; // 默认值6,限定 WorkerId 最大值为2^6-1,即默认最多支持64个节点。 // options.WorkerIdBitLength = 10; // 默认值6,限定 WorkerId 最大值为2^6-1,即默认最多支持64个节点。
// options.SeqBitLength = 6; // 默认值6,限制每毫秒生成的ID个数。若生成速度超过5万个/秒,建议加大 SeqBitLength 到 10。 // options.SeqBitLength = 6; // 默认值6,限制每毫秒生成的ID个数。若生成速度超过5万个/秒,建议加大 SeqBitLength 到 10。
// options.BaseTime = Your_Base_Time; // 如果要兼容老系统的雪花算法,此处应设置为老系统的BaseTime。 // options.BaseTime = Your_Base_Time; // 如果要兼容老系统的雪花算法,此处应设置为老系统的BaseTime。
// ...... 其它参数参考 IdGeneratorOptions 定义。 // ...... 其它参数参考 IdGeneratorOptions 定义。
// 保存参数(务必调用,否则参数设置不生效): // 保存参数(务必调用,否则参数设置不生效):
YitIdHelper.SetIdGenerator(options); YitIdHelper.SetIdGenerator(options);
// 以上过程只需全局一次,且应在生成ID之前完成。 // 以上过程只需全局一次,且应在生成ID之前完成。
``` ```
第2步,生成ID: 第2步,生成ID:
``` ```
// 初始化后,在任何需要生成ID的地方,调用以下方法: // 初始化后,在任何需要生成ID的地方,调用以下方法:
long newId = YitIdHelper.nextId(); long newId = YitIdHelper.nextId();
``` ```
此差异已折叠。
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册