站长网 语言 Go泛型系列 Maps 包有哪些?

Go泛型系列 Maps 包有哪些?

真实的场景 不少新手,对 map 的输出是随机的有迷惑,曾经,map 的输出顺序是固定的,但官方怕大家依赖这个顺序,之后故意让输出顺序不固定。 但实际场景中,会有按某种顺序输出 map 的需求,怎么办呢?这需要对 map 的 key 进行排序,伪代码如下: for k :=

真实的场景
不少新手,对 map 的输出是随机的有迷惑,曾经,map 的输出顺序是固定的,但官方怕大家依赖这个顺序,之后故意让输出顺序不固定。
 
但实际场景中,会有按某种顺序输出 map 的需求,怎么办呢?这需要对 map 的 key 进行排序,伪代码如下:
 
for k := m {
  keys = append(keys, k)
}
sort(keys)
类似的代码会经常需要写,关键是,因为没有泛型,我们还没法写一个通用函数,复用代码。
 
 maps 包详解
目前 maps 包有 8 个函数:
 
func Keys[M ~map[K]V, K comparable, V any](m M) []K
func Values[M ~map[K]V, K comparable, V any](m M) []V
func Equal[M1, M2 ~map[K]V, K, V comparable](m1 M1, m2 M2) bool
func EqualFunc[M1 ~map[K]V1, M2 ~map[K]V2, K comparable, V1, V2 any](m1 M1, m2 M2, eq func(V1, V2) bool) bool
func Clear[M ~map[K]V, K comparable, V any](m M)
func Clone[M ~map[K]V, K comparable, V any](m M) M
func Copy[M ~map[K]V, K comparable, V any](dst, src M)
func DeleteFunc[M ~map[K]V, K comparable, V any](m M, del func(K, V) bool)
其中 Keys 就是上面说的场景,提取出 map 中所有的 key,组成一个 slice,方便做排序。相应的,Values 函数就是获取所有的 value,组成一个 slice。
 
func Keys[M ~map[K]V, K comparable, V any](m M) []K {
 r := make([]K, 0, len(m))
 for k := range m {
  r = append(r, k)
 }
 return r
}
留意类型约束:~map[K]V,表明只要底层类型是 map 就适用,即适用自定义的 map 类型。上面函数的类型约束还说明,map 中,key 必须是可比较的,即 comparable 的,而 value 可以是任意类型,即 any。
 
Equal 和 EqualFunc 用于比较两个 map 是否有相同的键值对,用的应该不多。
 
至于 Clone 和 Copy,Clone 用于克隆出一个新的 map,key 和 value 和原来的一致,不过不是深度克隆,也就是说 value 可能指向同一个。
 
而 Copy 可以将 src 中的 key/value 全部复制到 dst 中,如果 dst 中存在同样的 key,会覆盖。
 
Clear 和 DeleteFunc 用于删除 map 的键值对。
 
maps 包代码不到 100 行,实现很简单,很容易看懂。不过大家需要认真看懂函数的签名,因为泛型的引入,导致函数签名比之前的函数签名复杂很多。

本文来自网络,不代表站长网立场,转载请注明出处:https://www.tzzz.com.cn/html/biancheng/yuyan/2021/1206/33971.html

作者: dawei

【声明】:站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。
联系我们

联系我们

0577-28828765

在线咨询: QQ交谈

邮箱: xwei067@foxmail.com

工作时间:周一至周五,9:00-17:30,节假日休息

返回顶部