- 属性复制
- 分布式雪花算法
- 缓存(redis)
- 字符
- 文件
- json
- 时间日期
- 条件表达式
- 协程池
- 切片 ...
- v1.0.1:雪花算法
- v1.0.0:bean属性拷贝
安装
go get -u github.com/wegoteam/wepkg
type A struct {
Int int
String string
}
func TestBeanCopy(t *testing.T) {
a1 := &A{Int: 100}
a2 := &A{}
copy.BeanCopy(a1, a2)
fmt.Println(a1, a2)
}
/**
Method:雪花计算方法,(1-漂移算法|2-传统算法),默认1
BaseTime:基础时间(ms单位),不能超过当前系统时间
WorkerId:机器码,必须由外部设定,最大值 2^WorkerIdBitLength-1
WorkerIdBitLength:机器码位长,默认值6,取值范围 [1, 15](要求:序列数位长+机器码位长不超过22)
SeqBitLength:序列数位长,默认值6,取值范围 [3, 21](要求:序列数位长+机器码位长不超过22)
MaxSeqNumber:最大序列数(含),设置范围 [MinSeqNumber, 2^SeqBitLength-1],默认值0,表示最大序列数取最大值(2^SeqBitLength-1])
MinSeqNumber:最小序列数(含),默认值5,取值范围 [5, MaxSeqNumber],每毫秒的前5个序列数对应编号0-4是保留位,其中1-4是时间回拨相应预留位,0是手工新值预留位
TopOverCostCount:最大漂移次数(含),默认2000,推荐范围500-10000(与计算能力有关)
*/
func TestSnowflake(t *testing.T) {
// 创建配置对象
var options = snowflake.NewSnowflakeOptions(1)
options.Method = 1
options.WorkerIdBitLength = 6
options.SeqBitLength = 6
// 保存配置
snowflake.SetSnowflakeOptions(options)
for {
//生成ID
var newId = snowflake.GenSnowflakeId()
fmt.Println(newId)
time.Sleep(time.Second)
}
}