Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
yitter
雪花ID全家桶(SnowFlake IdGenerator)
提交
baaf1a49
雪
雪花ID全家桶(SnowFlake IdGenerator)
项目概览
yitter
/
雪花ID全家桶(SnowFlake IdGenerator)
9 个月 前同步成功
通知
201
Star
3
Fork
1
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
雪
雪花ID全家桶(SnowFlake IdGenerator)
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
baaf1a49
编写于
10月 17, 2022
作者:
yitter
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
auto commit
上级
20c6d38f
变更
4
展开全部
隐藏空白更改
内联
并排
Showing
4 changed file
with
385 addition
and
385 deletion
+385
-385
C#.NET/README.md
C#.NET/README.md
+37
-37
Delphi/source/.gitignore
Delphi/source/.gitignore
+5
-5
Java/README.md
Java/README.md
+39
-39
README.md
README.md
+304
-304
未找到文件。
C#.NET/README.md
浏览文件 @
baaf1a49
# ❄ 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();
```
```
Delphi/source/.gitignore
浏览文件 @
baaf1a49
Win32/
Win32/
*.exe
*.exe
*.dproj.local
*.dproj.local
*.identcache
*.identcache
__*
__*
Java/README.md
浏览文件 @
baaf1a49
# ❄ 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();
```
```
README.md
浏览文件 @
baaf1a49
此差异已折叠。
点击以展开。
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录