【Go Generics】泛型为何而生的

结论:它的诞生是为了解决:重载

泛型是 Go 1.18 才加入的核武器,它的诞生是为了解决另一个痛苦:代码极其恶心的重复(Don't Repeat Yourself)。

没有泛型时的痛苦(逼死强迫症)

假设你在公共库 morph 里,想写一个工具函数:传入两个整数,返回最大的那一个。

复制代码
func MaxInt(a, b int) int {
    if a > b { return a }
    return b
}

写完没几天,你发现业务里还需要对比两个 float64、两个 int64 的大小。

在没有泛型的时候,Go 官方又没有重载(Overload)功能,你只能痛苦地复制粘贴,写出极其丑陋的代码:

Go 复制代码
func MaxFloat64(a, b float64) float64 { ... }
func MaxInt64(a, b int64) int64 { ... }

全天下写 Go 的人都在骂:就为了改个类型,老子要写三遍一模一样的逻辑,这不纯粹是体力活吗?

有了泛型(Generics)后的终极救赎

泛型,顾名思义,就是"把类型当成变量一样传进去"。

有了泛型,你只需要写一个函数,就能通吃全天下所有的数字类型:

复制代码
// [T int | int64 | float64] 代表:这个函数支持这三种类型,用 T 来代替
func Max[T int | int64 | float64](a, b T) T {
    if a > b {
        return a
    }
    return b
}

当你调用时:

  • Max(1, 2) \\rightarrow Go 自动识别 Tint
  • Max(1.5, 2.5) \\rightarrow Go 自动识别 Tfloat64

总结:泛型的出现,是为了重载

让你在"逻辑完全相同,只有数据类型不同"的场景下(比如实现一个通用的切片去重、通用的 Map 过滤、或者通用的缓存加载),只写一份代码。

泛型(Generics)关注的是"数据类型(Type)":比如"不管是 int 还是 string,这段内存剥离逻辑都长一样"。它的核心是消除重复代码。

相关推荐
用户398346161202 小时前
Go-Spring 实战第 8 课 —— 变量引用与动态刷新:配置值如何复用和更新
spring·go
小羊在睡觉1 天前
力扣239. 滑动窗口最大值
数据结构·后端·算法·leetcode·go
用户398346161201 天前
Go-Spring 实战第 7 课 —— Profile 多环境配置:基础配置与环境差异如何避免复制
spring·go
审判长烧鸡1 天前
【Go Context】终极指南
go
审判长烧鸡1 天前
【Go Test】单元测试保姆级完整指南
单元测试·go
审判长烧鸡2 天前
【Go工具】go-playground是什么组织?官方的?
开发语言·安全·go
别样的感动2 天前
我写了一个 Go 框架:用 DSL 替代 ORM,代码体积减半,开发效率翻倍
go
明月_清风2 天前
Go语言空接口与类型断言完全指南:从"万能容器"到"类型还原"
后端·go
蓝宝石的傻话2 天前
security-collector-exporter:用Prometheus 解决 Linux 的安全审计
go