gset
同时,支持可选的并发安全参数选项,支持并发安全的场景。
使用场景:
集合操作。
使用方式:
package main
import (
"github.com/gogf/gf/container/gset"
"fmt"
)
func main() {
// 创建一个并发安全的集合对象
s := gset.New(true)
// 添加数据项
s.Add(1)
// 批量添加数据项
s.Add([]interface{}{1, 2, 3}...)
// 集合数据项大小
fmt.Println(s.Size())
// 集合中是否存在指定数据项
fmt.Println(s.Contains(2))
// 返回数据项slice
fmt.Println(s.Slice())
// 删除数据项
s.Remove(3)
// 遍历数据项
s.Iterator(func(v interface{}) bool {
fmt.Println("Iterator:", v)
return true
})
// 将集合转换为字符串
fmt.Println(s.String())
// 并发安全写锁操作
s.LockFunc(func(m map[interface{}]struct{}) {
})
// 并发安全读锁操作
fmt.Println(m)
})
// 清空集合
s.Clear()
fmt.Println(s.Size())
}
执行后,输出结果为:
3
true
[1 2 3]
Iterator: 1
Iterator: 2
[1 2]
map[1:{} 2:{} 4:{}]
0
我们可以使用以下方法实现交差并补集,并返回一个新的结果集合,
Intersect
: 交集,属于set或属于others的元素为元素的集合。Diff
: 差集,属于set且不属于others的元素为元素的集合。Union
: 并集,属于set或属于others的元素为元素的集合。Complement
: 补集,(前提: set应当为full的子集)属于全集full不属于集合set的元素组成的集合。如果给定的full集合不是set的全集时,返回full与set的差集.
通过集合方法我们可以发现,交差并集方法支持多个集合参数进行计算。以下为简化示例,只使用一个参数集合。
package main
import (
"fmt"
"github.com/gogf/gf/frame/g"
"github.com/gogf/gf/container/gset"
)
func main() {
s1 := gset.NewFrom(g.Slice{1, 2, 3})
s2 := gset.NewFrom(g.Slice{4, 5, 6})
s3 := gset.NewFrom(g.Slice{1, 2, 3, 4, 5, 6, 7})
// 交集
fmt.Println(s3.Intersect(s1).Slice())
// 差集
fmt.Println(s3.Diff(s1).Slice())
// 并集
fmt.Println(s1.Union(s2).Slice())
// 补集
fmt.Println(s1.Complement(s3).Slice())
}
执行后,输出结果为:
[4 5 6 7]
[1 2 3 4 5 6]
Marshal
执行后,输出结果:
{"Id":1,"Name":"john","Scores":[100,99,98]}
Unmarshal
package main
import (
"encoding/json"
"fmt"
"github.com/gogf/gf/container/gset"
)
func main() {
b := []byte(`{"Id":1,"Name":"john","Scores":[100,99,98]}`)
type Student struct {
Id int
Name string
Scores *gset.IntSet
}
s := Student{}
json.Unmarshal(b, &s)
fmt.Println(s)
}
执行后,输出结果:
性能测试
goos: darwin
goarch: amd64
Benchmark_IntSet_Add-4 10000000 277 ns/op 8 B/op 0 allocs/op
Benchmark_IntSet_Contains-4 20000000 60.6 ns/op 0 B/op 0 allocs/op
Benchmark_IntSet_Remove-4 10000000 211 ns/op 0 B/op 0 allocs/op
Benchmark_AnySet_Add-4 5000000 312 ns/op 21 B/op 1 allocs/op
Benchmark_AnySet_Contains-4 30000000 68.2 ns/op 0 B/op 0 allocs/op
Benchmark_AnySet_Remove-4 5000000 267 ns/op 0 B/op 0 allocs/op
Benchmark_StrSet_Add-4 5000000 383 ns/op 20 B/op 1 allocs/op
Benchmark_StrSet_Contains-4 10000000 160 ns/op 7 B/op 0 allocs/op
Benchmark_StrSet_Remove-4 5000000 306 ns/op 7 B/op 0 allocs/op
Benchmark_Unsafe_IntSet_Add-4 10000000 258 ns/op 35 B/op 0 allocs/op
Benchmark_Unsafe_IntSet_Contains-4 20000000 146 ns/op 0 B/op 0 allocs/op
Benchmark_Unsafe_IntSet_Remove-4 10000000 173 ns/op 0 B/op 0 allocs/op
Benchmark_Unsafe_AnySet_Add-4 5000000 355 ns/op 41 B/op 1 allocs/op
Benchmark_Unsafe_AnySet_Contains-4 10000000 150 ns/op 0 B/op 0 allocs/op
Benchmark_Unsafe_AnySet_Remove-4 200000000 11.9 ns/op 0 B/op 0 allocs/op
Benchmark_Unsafe_StrSet_Add-4 5000000 486 ns/op 59 B/op 1 allocs/op
Benchmark_Unsafe_StrSet_Contains-4 5000000 298 ns/op 7 B/op 0 allocs/op
Benchmark_Unsafe_StrSet_Remove-4 10000000 158 ns/op 7 B/op 0 allocs/op