当前位置: 首页 > news >正文

Go小技巧易错点100例(二十九)

随着 Go 语言的不断迭代,新版本带来了许多实用的标准库函数,使得代码更加简洁、可读性更强。本篇文章主要介绍 Go 1.21+ 版本中的一些新特性,涵盖 可变类型比较、slice 最大值与最小值、map 转换为 slice 以及 map 合并 等常见场景,展示如何利用新特性优化代码。

本期分享:

1.可变类型比较

2.Slice 最大值与最小值

3.Map 转换为 Slice

4.Map 合并


可变类型比较

在 Go 语言中,比较两个数的大小通常使用 if 语句,但 Go 1.21 之后引入了新的内置函数,比如 max()min()

旧写法

oldFunc := func(a, b int) (int, int) {maxValue := aif a < b {maxValue = b}minValue := aif a > b {minValue = b}return maxValue, minValue
}

新写法

newFunc := func(i, j int) (int, int) {maxValue := max(i, j)minValue := min(i, j)return maxValue, minValue
}

注意点

如果我们看下源码:

func max[T cmp.Ordered](x T, y ...T) T

不难发现这个函数的参数貌似支持一个数字和一个数组一起进行比较,然后我们试一下:

newFunc := func(i int, l ...int) (int, int) {fmt.Println(max(i, l...)) // ...
}

就会发现编译的时候会报错:invalid use of ... with built-in max。这是为什么呢?

因为在Go语言中,... 是用于可变参数函数的语法糖。当你在函数调用中使用 ... 时,它会将一个切片展开为多个参数。然而,Go语言的内置函数 max 和 min 并不支持可变参数,因此你不能在调用这些函数时使用 ...

Slice 最大值与最小值

在旧版本中,需要手动遍历 slice 来求最大/最小值。而在 Go 1.21+ 中,slices.Maxslices.Min 让这件事变得更简单。

旧写法

oldFunc := func(s []int) (int, int) {maxValue := s[0]for i := 1; i < len(s); i++ {maxValue = max(maxValue, s[i])}minValue := s[0]for i := 1; i < len(s); i++ {minValue = min(minValue, s[i])}return maxValue, minValue
}

新写法

import "slices"newFunc := func(s []int) (int, int) {maxValue := slices.Max(s)minValue := slices.Min(s)return maxValue, minValue
}

Map 转换为 Slice

在开发过程中,我们经常需要将 map 的 key 或 value 提取为 slice。Go 1.21 之前,需要手动遍历 map,而新版本提供了 maps.Keysmaps.Values

旧写法

oldFunc := func(m map[string]string) ([]string, []string) {keys := make([]string, 0, len(m))for key := range m {keys = append(keys, key)}values := make([]string, 0, len(m))for _, value := range m {values = append(values, value)}return keys, values
}

新写法

import "maps"newFunc := func(m map[string]string) ([]string, []string) {keys := slices.Collect(maps.Keys(m))values := slices.Collect(maps.Values(m))return keys, values
}

Map 合并

Go 1.21 之前,map 合并需要手写循环,而新版本引入了 maps.Insert,让 map 合并变得更加简单。

旧写法

oldFunc := func(m1, m2 map[string]int) map[string]int {dst := map[string]int{"c": 3, "d": 4}for k, v := range m1 {dst[k] = v}return dst
}

新写法

newFunc := func(m1, m2 map[string]int) map[string]int {dst := map[string]int{"c": 3, "d": 4}maps.Insert(dst, maps.All(m1))return dst
}

本篇结束~

相关文章:

  • 关于毕业论文,查重,AIGC
  • 【漫话机器学习系列】240.真正类率(True Positive Rate,TPR)
  • C++演讲比赛案例代码
  • AI日报 · 2025年5月05日|雅诗兰黛与微软合作成立 AI 创新实验室,加速美妆产品研发与营销
  • LCD,LED
  • AI笔记-1
  • 稀疏性预测算法初步
  • 文心一言开发指南13——文心一言API两种调用方式的区别
  • cpp学习笔记1--class
  • 【QT】QT安装
  • Python生活手册-NumPy数组创建:从快递分拣到智能家居的数据容器
  • Springboot循环依赖
  • React-router v7 第八章(边界处理)
  • AI向量检索
  • DeepSeek提示词的技巧
  • URL混淆与权限绕过技术
  • Linux | WEB服务器的部署及优化
  • Doo全自动手机壳定制系统
  • 安全为上,在系统威胁建模中使用量化分析
  • 5G网络的安全挑战与应对策略:技术剖析与Python实战
  • 实探北京楼市:“好房子”卖点十足,二手房持续回稳
  • 伯克希尔董事会投票决定:阿贝尔明年1月1日起出任CEO,巴菲特继续担任董事长
  • 特朗普要征100%关税,好莱坞这批境外摄制新片能躲过吗?
  • 马斯克的“星舰基地”成为新城镇,首任市长为SpaceX员工
  • 热点问答|澳大利亚联邦选举结果有何看点
  • 加拿大总理将赴美同特朗普会晤,重点谈贸易压力