collection库更新1.4.0版本

collection库更新1.4.0版本

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:11:22:3}IntCollection(3):{0:41:52:6}IntCollection(2):{0:71: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: 1Int32Collection(2):{0:11:1}    /Users/yejianfeng/Documents/workspace/collection/int32_collection_test.go:97: 20Int32Collection(1):{0:20}    /Users/yejianfeng/Documents/workspace/collection/int32_collection_test.go:97: 4Int32Collection(1):{0:4}*/

其实还做了几个事情:

1 把测试用例优化了一些,里面有一些直接dd的,感觉比较丑,就去掉了

2 文档补充了一下,包括readme和官方文档

3 官网也顺手更新了一下,http://collection.funaio.cn/ 。不过好像github有个action机制,还没研究清楚怎么更新github同时更新自己服务器上的vuepress。

完结,周末愉快~

免责声明:本网信息来自于互联网,目的在于传递更多信息,并不代表本网赞同其观点。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,并请自行核实相关内容。本站不承担此类作品侵权行为的直接责任及连带责任。如若本网有任何内容侵犯您的权益,请及时联系我们,本站将会在24小时内处理完毕。
相关文章
返回顶部