如果用过 laravel collection ,js lodash 、underscore 基本上就知道这个包想干啥了。
相信每一位 go 开发者都遇到过这种情况: 同样的循环,同样的逻辑,只是不同的入参[]int/[]string/[]interface{}。但是我们要写 N 个方法去分别处理这些数据,现在有了泛型,我们就可以轻松一点了。
其实类似的项目也有,不过我最喜欢还是 collection 的使用风格,所以在 1.18 正式发布之际,写了个基于泛型的工具。
//对称差级
expected := map[string]int{"b": 2, "c": 3}
actual := NewMapCollection(map[string]int{"a": 1, "b": 2}).SymmetricDiff(map[string]int{"a": 1, "c": 3}).All()
assert.Equal(t, expected, actual)
//对称差集 = 相互的差集再并集
func (co *MapCollection[K, V]) SymmetricDiff(items map[K]V) *MapCollection[K, V] {
return co.Diff(items).Union(NewMapCollection(items).Diff(co.items).All())
}
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.