# Maputil maputil 包包括一些操作 map 的函数。
## 源码: - [https://github.com/duke-git/lancet/blob/main/maputil/map.go](https://github.com/duke-git/lancet/blob/main/maputil/map.go)
## 用法: ```go import ( "github.com/duke-git/lancet/v2/maputil" ) ```
## 目录: - [ForEach](#ForEach) - [Filter](#Filter) - [Intersect](#Intersect) - [Keys](#Keys) - [Merge](#Merge) - [Minus](#Minus) - [Values](#Values) - [IsDisjoint](#IsDisjoint)
## API 文档: ### ForEach

对map中的每对key和value执行iteratee函数

函数签名: ```go func ForEach[K comparable, V any](m map[K]V, iteratee func(key K, value V)) ``` 示例: ```go package main import ( "fmt" "github.com/duke-git/lancet/v2/maputil" ) func main() { m := map[string]int{ "a": 1, "b": 2, "c": 3, "d": 4, } var sum int maputil.ForEach(m, func(_ string, value int) { sum += value }) fmt.Println(sum) // Output: // 10 } ``` ### Filter

迭代map中的每对key和value, 返回符合predicate函数的key, value

函数签名: ```go func Filter[K comparable, V any](m map[K]V, predicate func(key K, value V) bool) map[K]V ``` 示例: ```go package main import ( "fmt" "github.com/duke-git/lancet/v2/maputil" ) func main() { m := map[string]int{ "a": 1, "b": 2, "c": 3, "d": 4, "e": 5, } isEven := func(_ string, value int) bool { return value%2 == 0 } maputil.Filter(m, func(_ string, value int) { sum += value }) result := Filter(m, isEven) fmt.Println(result) // Output: // map[b:2 d:4] } ``` ### Intersect

多个map的交集操作

函数签名: ```go func Intersect[K comparable, V any](maps ...map[K]V) map[K]V ``` 示例: ```go package main import ( "fmt" "github.com/duke-git/lancet/v2/maputil" ) func main() { m1 := map[string]int{ "a": 1, "b": 2, "c": 3, } m2 := map[string]int{ "a": 1, "b": 2, "c": 6, "d": 7, } m3 := map[string]int{ "a": 1, "b": 9, "e": 9, } result1 := maputil.Intersect(m1) result2 := maputil.Intersect(m1, m2) result3 := maputil.Intersect(m1, m2, m3) fmt.Println(result1) fmt.Println(result2) fmt.Println(result3) // Output: // map[a:1 b:2 c:3] // map[a:1 b:2] // map[a:1] } ``` ### Keys

返回map中所有key的切片

函数签名: ```go func Keys[K comparable, V any](m map[K]V) []K ``` 示例: ```go package main import ( "fmt" "github.com/duke-git/lancet/v2/maputil" ) func main() { m := map[int]string{ 1: "a", 2: "a", 3: "b", 4: "c", 5: "d", } keys := maputil.Keys(m) sort.Ints(keys) fmt.Println(keys) // Output: // [1 2 3 4 5] } ``` ### Merge

合并多个maps, 相同的key会被后来的key覆盖

函数签名: ```go func Merge[K comparable, V any](maps ...map[K]V) map[K]V ``` 示例: ```go package main import ( "fmt" "github.com/duke-git/lancet/v2/maputil" ) func main() { m1 := map[int]string{ 1: "a", 2: "b", } m2 := map[int]string{ 1: "1", 3: "2", } result := maputil.Merge(m1, m2) fmt.Println(result) // Output: // map[1:c 2:b 3:d] } ``` ### Minus

返回一个map,其中的key存在于mapA,不存在于mapB.

函数签名: ```go func Minus[K comparable, V any](mapA, mapB map[K]V) map[K]V ``` 示例: ```go package main import ( "fmt" "github.com/duke-git/lancet/v2/maputil" ) func main() { m1 := map[string]int{ "a": 1, "b": 2, "c": 3, } m2 := map[string]int{ "a": 11, "b": 22, "d": 33, } result := maputil.Minus(m1, m2) fmt.Println(result) // Output: // map[c:3] } ``` ### Values

返回map中所有value的切片

函数签名: ```go func Values[K comparable, V any](m map[K]V) []V ``` 示例: ```go package main import ( "fmt" "github.com/duke-git/lancet/v2/maputil" ) func main() { m := map[int]string{ 1: "a", 2: "a", 3: "b", 4: "c", 5: "d", } values := maputil.Values(m) sort.Strings(values) // Output: // [a a b c d] } ``` ### IsDisjoint

验证两个map是否具有不同的key

函数签名: ```go func IsDisjoint[K comparable, V any](mapA, mapB map[K]V) bool ``` 示例: ```go package main import ( "fmt" "github.com/duke-git/lancet/v2/maputil" ) func main() { m1 := map[string]int{ "a": 1, "b": 2, "c": 3, } m2 := map[string]int{ "d": 22, } m3 := map[string]int{ "a": 22, } result1 := maputil.IsDisjoint(m1, m2) result2 := maputil.IsDisjoint(m1, m3) fmt.Println(result1) fmt.Println(result2) // Output: // true // false } ```