collection庫更新1.4.0版本
collection庫一直在使用中,週末集合github上的反饋以及contributor的修改,更新了1.4.0版本。
這個版本做了幾個事情:
增加了三種型別, uint, uint32, uint64
這三種型別也算基礎型別了,目前基本上已經把所有基礎型別都覆蓋了,一共十一種型別:
int32, int, int64, uint32, uint, uint64, float32, float64, string, object, objectPoint
增加Split和GroupBy方法
這兩個方法其實都是將一個collection進行分組。Split是根據個數,將陣列分成幾份,比如
intColl := NewIntCollection([]int{1, 2, 3, 4, 5, 6, 7, 8})
ret := intColl.Split(3)
if len(ret) != 3 {
t.Fatal("split len not right")
}
ret[0].DD()
ret[1].DD()
ret[2].DD()
按照size為3分成3個部分
IntCollection(3):{
0: 1
1: 2
2: 3
}
IntCollection(3):{
0: 4
1: 5
2: 6
}
IntCollection(2):{
0: 7
1: 8
}
而GroupBy 是同事使用的時候提的一個需求,需要按照某個函式進行歸類,然後輸出,類似於spark中的GroupBy運算元
func TestInt32Collection_GroupBy(t *testing.T) {
objColl := NewInt32Collection([]int32{1, 1, 20, 4})
groupBy := objColl.GroupBy(func(item interface{}, i2 int) interface{} {
foo := item.(int32)
return foo
})
for k, collection := range groupBy {
t.Log(k)
collection.DD()
}
}
/*
=== RUN TestInt32Collection_GroupBy
/Users/yejianfeng/Documents/workspace/collection/int32_collection_test.go:97: 1
Int32Collection(2):{
0: 1
1: 1
}
/Users/yejianfeng/Documents/workspace/collection/int32_collection_test.go:97: 20
Int32Collection(1):{
0: 20
}
/Users/yejianfeng/Documents/workspace/collection/int32_collection_test.go:97: 4
Int32Collection(1):{
0: 4
}
*/
其實還做了幾個事情:
1 把測試用例優化了一些,裡面有一些直接dd的,感覺比較醜,就去掉了
2 文件補充了一下,包括readme和官方文件
3 官網也順手更新了一下,http://collection.funaio.cn/ 。不過好像github有個action機制,還沒研究清楚怎麼更新github同時更新自己伺服器上的vuepress。
完結,週末愉快~