Go 1.21.0 新增标准库 Slices 和 Mps 详解

开发 前端
本文我们简单介绍 Go 1.21.0 新增标准库 slices​ 和 maps​,标准库提供了一些操作 slice​ 和 map​ 的函数,限于篇幅,分别介绍 slices​ 的查找功能的函数,和 maps 的比较相同功能的函数。

01 、介绍

在 Go 语言项目开发中,我们经常会使用 slice 和 map 数据类型,因为 Go 1.18.0 开始支持泛型,所以 slice 的元素可能是任意类型,map 的 key 和 value 也可能是任意类型。

Go 1.21.0 新增操作 slice 和 map 数据类型的标准库 slices 和 maps,提供了操作 slice 和 map 的泛型函数。

本文我们介绍标准库 slices 和 maps 的使用方式。

02 、标准库 slices

标准库 slices 提供了许多操作任意类型元素 slice 的函数,可以方便我们实现业务需求。

建议感兴趣的读者朋友们阅读手册了解关于标准库 slices[1] 的所有函数的功能。

限于篇幅,我们介绍关于查找的函数的使用方式。

查找功能的函数 BinarySearch 和 BinarySearchFunc。

函数 BinarySearch 示例代码:

func main() {
 names := []string{"Alice", "Bob", "Vera"}
 n, found := slices.BinarySearch(names, "Vera")
 fmt.Println("Vera:", n, found)
 n, found = slices.BinarySearch(names, "Bill")
 fmt.Println("Bill:", n, found)
}

输出结果:

Vera: 2 true
Bill: 1 false

阅读上面这段代码,我们定义一个字符串元素类型的切片 names,使用标准库 slices 提供的二分查找函数 BinarySearch 查找 names 切片中的元素 Vera。

该函数返回被查找元素在切片中的索引位置或被查找元素在切片中应该出现的位置,和被查找元素是否真实存在于切片中的一个布尔值。

什么是被查找元素在切片中应该出现的位置?示例代码中,查找 Bill,切片中没有该元素,按照切片中递增排序,Bill 应该在 Alice 后面,即索引为 1。

需要注意的是,使用函数 BinarySearch 查找元素的切片,切片中的元素必须是按照递增顺序排序。

函数 BinarySearchFunc 示例代码:

func main() {
 type Person struct {
  Name string
  Age  int
 }
 people := []Person{
  {"Alice", 55},
  {"Bob", 24},
  {"Gopher", 13},
 }
 n, found := slices.BinarySearchFunc(people, Person{"Bob", 0}, func(a, b Person) int {
  return cmp.Compare(a.Name, b.Name)
 })
 fmt.Println("Bob:", n, found)
}

输出结果:

Bob: 1 true

阅读上面这段代码,函数 BinarySearchFunc 与 函数 BinarySearch 的功能类似,区别是可以使用自定义比较函数。

03 、标准库 maps

标准库 maps 提供了许多操作任意类型 key 和 value 的 map 的函数,可以方便我们实现业务需求。

建议感兴趣的读者朋友们阅读手册了解关于标准库 maps[2] 的所有函数的功能。

限于篇幅,我们介绍关于比较两个 map 中的 key 和 value 是否相同的函数的使用方式。

函数 Equal 示例代码:

func main() {
 m1 := map[string]int{"lucy": 17, "lily": 18}
 m2 := map[string]int{"lucy": 17, "lily": 18}
 m3 := map[string]int{"lucy": 18, "lily": 17}
 fmt.Println(maps.Equal(m1, m2))
 fmt.Println(maps.Equal(m1, m3))
}

输出结果:

true
false

阅读上面这段代码,我们定义三个 map 类型的变量,其中 m1 和 m2 的 key 和 value 完全相同,而 m3 的 value 与 m1 和 m2 的 value 不同。

使用函数 Equal 比较,分别返回 true 和 false。

需要注意的是 map 的 key 和 value 必须都是可比较的类型。

函数 EqualFunc 和函数 Equal 的功能类似,区别是使用 eq 比较 value。key 仍然使用比较运算符 == 进行比较。

函数 EqualFunc 示例代码:

func main() {
 m1 := map[int]string{
  1:    "one",
  10:   "Ten",
  1000: "THOUSAND",
 }
 m2 := map[int][]byte{
  1:    []byte("One"),
  10:   []byte("Ten"),
  1000: []byte("Thousand"),
 }
 eq := maps.EqualFunc(m1, m2, func(v1 string, v2 []byte) bool {
  return strings.ToLower(v1) == strings.ToLower(string(v2))
 })
 fmt.Println(eq)
}

输出结果:

true

04、总结

本文我们简单介绍 Go 1.21.0 新增标准库 slices 和 maps,标准库提供了一些操作 slice 和 map 的函数,限于篇幅,分别介绍 slices 的查找功能的函数,和 maps 的比较相同功能的函数。

建议读者朋友们,阅读文档,了解标准库提供的所有函数的功能和使用方式。

责任编辑:武晓燕 来源: Golang语言开发栈
相关推荐

2023-10-07 00:10:27

日志格式函数

2023-11-03 14:02:04

Go切片泛型库

2023-04-02 23:13:07

Go语言bufio

2023-05-05 08:51:18

Go语言泛型

2021-08-09 10:36:20

GoSlices Maps

2021-11-27 22:20:13

SlicesGo泛型

2021-08-13 12:05:15

Goneturl

2021-12-10 15:22:26

Go Zip 文件

2023-10-11 08:45:55

Go标准库指标

2021-10-18 10:53:26

Go 代码技术

2023-11-01 08:41:24

Go标准库http

2023-12-26 07:37:27

2014-01-14 09:10:53

GoHTTP内存泄漏

2023-12-04 08:46:40

Go标准库

2023-04-17 14:32:20

2023-06-07 10:32:57

内置函数clear

2021-09-26 09:56:24

CookieSameParty前端

2009-09-27 10:03:53

Silverlight

2021-08-01 00:08:06

JsonGo标准库

2021-12-02 18:21:49

GoIP 包设计
点赞
收藏

51CTO技术栈公众号