GO错误处理【6】显式哲学

我拷,我算是知道为什么到处都要求"显式"了,不光错误要求显示,定义要求显式,在GO里面几乎都要求显式,

Go 的哲学是 "显式优于隐式"

没错!在 PHP 里,异常像电梯,报错了直接"嗖"地一下穿透所有楼层直到被 catch。但在 Go 里,错误像爬楼梯,你必须手递手地把 err 交给上一层,否则上一层根本不知道楼下"起火"了。

1. 为什么"不显式"就返不了?

因为 Go 认为:函数返回值就是它唯一的合法出口。

  • 如果你不把 err 写在返回值里,这个错误信息就会在函数执行完的那一刻原地蒸发(除非你用 panic 这种暴力手段)。
  • 后果:如果你在 Repo 里查库失败了但不返回 err,你的 Logic 层会拿到一个零值的结构体,开心地继续往下跑,最后在某个地方报一个莫名其妙的空指针错误。那时候你再去查日志,发现数据库那层安静得像什么都没发生过。

2. 这种"显式"带给你的 3 大好处

虽然写 if err != nil 确实有点机械劳动,但它解决了 PHP 开发者最头疼的三个问题:

  1. 错误不被淹没:在 PHP 里,你可能调用了一个函数,它内部 try-catch 后没抛出来,导致你以为成功了。在 Go 里,只要你没处理那个返回的 err,它就永远在那"瞪着"你。
  2. 路径清晰:你可以一眼看出一个复杂的业务逻辑里,到底有多少个环节可能出岔子。
  3. 精确控制:你可以决定在 Logic 层处理掉这个错(比如报错了就用默认值),还是继续往上传。这种灵活性是 try-catch 很难做到的。

3. 给老哥的"职业病"预警

当你写多了 Go 之后,你会产生一种"不看 err 心慌"的职业病:

  • 看到 val, _ := someFunc()(用下划线忽略错误),你会觉得这行代码像个定时炸弹。
  • 看到一个函数只返回数据不返回 err,你会忍不住怀疑:万一它失败了怎么办?

4. 总结你的心路历程

  • 初期:觉得 Go 真笨,连个异常捕获都没有,天天写 if err
  • 中期:发现"显式"其实是为了责任到人,每一层都得对错误表态。
  • 现在:明白了!因为要包装 (%w),因为要形成链条,所以必须显式返回,否则日志就没法玩了。
相关推荐
小羊在睡觉9 小时前
力扣239. 滑动窗口最大值
数据结构·后端·算法·leetcode·go
用户3983461612010 小时前
Go-Spring 实战第 7 课 —— Profile 多环境配置:基础配置与环境差异如何避免复制
spring·go
审判长烧鸡12 小时前
【Go Context】终极指南
go
审判长烧鸡12 小时前
【Go Test】单元测试保姆级完整指南
单元测试·go
审判长烧鸡1 天前
【Go工具】go-playground是什么组织?官方的?
开发语言·安全·go
别样的感动1 天前
我写了一个 Go 框架:用 DSL 替代 ORM,代码体积减半,开发效率翻倍
go
明月_清风1 天前
Go语言空接口与类型断言完全指南:从"万能容器"到"类型还原"
后端·go
蓝宝石的傻话1 天前
security-collector-exporter:用Prometheus 解决 Linux 的安全审计
go
tyung1 天前
Go 手写二叉堆优先队列:避开 container/heap 的性能陷阱
数据结构·后端·go
审判长烧鸡2 天前
【PHPer转Go】fmt vs log/slog
go·php