【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,这段内存剥离逻辑都长一样"。它的核心是消除重复代码。

相关推荐
小满zs11 小时前
Go语言第二章(小无相功)
后端·go
妙码生花11 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十九):点选验证码代码逐行目检
前端·后端·go
老鹰86212 小时前
Google Wire 被官方抛弃,Uber Fx 启动就 panic,Go DI 还有救吗?
go
golang学习记19 小时前
Go面试官:说说struct{}为什么占用0字节
go
喵个咪2 天前
Go Wind UBA 拆解系列 - 架构总览:三服务、数据流与契约优先
大数据·后端·go
喵个咪2 天前
Go Wind UBA 拆解系列 - 多租户与安全:两套隔离机制的边界
大数据·后端·go
喵个咪2 天前
Go Wind UBA 拆解系列 - OLAP 与 SQL 硬核:25 个分析模型怎么落地
大数据·后端·go
喵个咪2 天前
Go Wind UBA 拆解系列 - SDK 与采集层:从浏览器到 Kafka
大数据·后端·go
小满zs2 天前
Go语言第一章(入门)
后端·go
唐青枫2 天前
别再把类型断言当强制转换:Go 从 comma-ok 到 type switch 实战详解
go