写了 10 年 Java/TS,Go 语言终于治好了我的“过度设计”绝症

本文永久链接 – https://tonybai.com/2026/05/16/go-cured-my-over-engineering-addiction-after-java-ts

大家好,我是Tony Bai。

在软件工程的圈子里,有一种病,几乎所有写过几年 Java 或 TypeScript 的程序员都得过,而且往往病得不轻。

这种病叫:“过度设计综合征(Over-engineering Syndrome)”

症状表现为:当你需要写一个简单的打印功能时,你脑子里第一反应不是写一行 print(“hello”),而是要去建一个 IPrinter 接口,然后搞一个 PrinterFactory 工厂类,再用依赖注入(DI)容器把一个单例的 ConsolePrinterImpl 塞进去。

美其名曰:为了未来的可扩展性。

结果呢?原本 10 行代码能搞定的事,被你写成了 100 行。半年后你自己回来看,连你都不知道那堆不知所云的接口到底在干嘛。

“在这些语言里,抽象,几乎变成了一项竞技体育。”

就在前几天,Reddit 的 r/golang 社区里,一篇名为Go 是让我最终停止过度设计的语言的帖子引发了各社区程序员的共鸣与热烈讨论。

帖子的作者讲述了自己从一个精通“代码杂技”的 TS/Java 老兵,在被 Go 语言“毒打”后,最终获得技术救赎的心路历程。

今天,我们就来看看 Go 语言究竟用了什么“黑魔法”,硬生生地把一群热衷于炫技的代码极客,改造成了最纯粹的实用主义者。

痛苦的戒断反应:当语言对你说“不”

原作者在帖子开头,极其生动地描述了他初遇 Go 语言时的崩溃感。

作为一个在 TS 生态里如鱼得水的老兵,他习惯了用各种高级特性去把代码写得“非常聪明(Clever)”。但当他在一个业余项目中开始使用 Go 时,他发现这门语言简直是个“直男”

“没有继承,没有魔法,没有花里胡哨的元编程技巧,甚至连个像样的通过注解实现的 DI 容器都没有。起初,这感觉就像是在束缚我,就像被迫只用一只手打字。

这几乎是所有高级语言开发者转向 Go 时的第一反应。你满脑子都是各种华丽的设计模式,但 Go 的编译器冷酷地告诉你:“对不起,这里不准炫技。”

你试图用多层继承来复用代码?Go 说不行,用组合。

你试图用 AOP(面向切面编程)来统一处理日志?Go 说不行,老老实实写中间件包裹函数。

你试图为了某个可能永远不会到来的需求提前写个抽象接口?Go 社区的规范告诉你:等你需要多个实现的时候再写,不要提早抽象!

在这个阶段,开发者往往会感到极度的痛苦和不适。因为他们赖以生存的、用来彰显自己“技术水平很高”的工具被彻底没收了。

顿悟的时刻:笨拙的胜利

然而,奇妙的事情在大约一个月后发生了。

作者写道:

“我的大脑突然‘翻转’了。我停止了试图在 Go 里玩那些聪明的 Java 技巧,开始老老实实地用 Go 的方式(boring go thing)做事。

突然之间,代码变得极其容易阅读。不仅仅是我的代码,我看过的每一个 Go 开源代码库,我都感觉阅读速度快得飞起。因为当你想要搞清楚它做了什么时,你只要找到它,就完了,你可以继续前进。”

这正是 Go 语言最核心的杀手锏:“代码可读性(Readability)”的降维打击。

在重度抽象的代码库中,逻辑是碎片化的。一半的代码是业务,另一半的代码是为了连接这些业务而存在的“管道(Plumbing)”。你为了追踪一个请求,可能要跳转 5 个接口定义和 3 个隐式绑定的工厂类。

而在 Go 里,一切都是直白的、平铺开的(Flat)。虽然你可能多写了几次同样的循环,多写了几遍看起来有点啰嗦的代码,但你永远不需要在一个又一个的接口跳转中迷失方向。

评论区里,一位开发者给出了一个让所有人拍案叫绝的回答:

“作为一个首席工程师,我现在的目标是:写出来的代码,必须要让一个初级工程师(Junior)觉得平易近人。我不在乎是否有一个更‘酷炫’的方法。一个初级工程师必须能接手我的工作并继续跑下去。所以,我遵循 KISS 原则(Keep It Simple, Stupid)。”

最牛逼的代码,不是写得像天书,而是写得像刚毕业的实习生也能一眼看懂的大白话。

争议的核心:“烦人的”错误处理,其实是防弹衣

当然,这场大讨论中不可避免地提到了 Go 语言常年被喷的最大痛点:满屏的 if err != nil { return err }。

习惯了 try-catch 一把梭的开发者觉得这简直是冗余的体力活。

但真正经历过生产环境毒打的老兵们,却对这种“烦人”的设计感恩戴德。

一位开发者的反思极其深刻:

“对我来说,转变最大的是错误处理。一开始那些 if err != nil 的样板代码看起来真的很蠢。直到你意识到:它强迫你主动思考可能发生的每一个单一的故障点,而不是像在那些支持异常(Exceptions)的语言里那样,抛出异常栈,然后祈祷上层有个 try/catch 把它接住。

这是一个正确的权衡(Right tradeoff):它让代码写起来慢,但读起来极其清晰。”

在 Java 里,一个未被捕获的异常可能在离案发地十万八千里的地方爆炸,留下一堆毫无线索的 Stack Trace。

而在 Go 里,每一个错误都像是一个显式的返回值,它逼着你在案发现场做出决定:是降级处理、是打日志、还是直接抛给上层。

这种在编码阶段的“精神折磨”,换来的是在凌晨三点排查线上故障时的“心如止水”。

反思:语言塑造思维

在讨论的末尾,原作者提到了一个极其令人震撼的个人体验:

“最巨大的好处发生在 6 个月后。我打开了一个我几个月没碰过的 Go 服务,我居然在 20 分钟内就完全找回了状态。这在我以前用其他语言自己写的代码库里,是从未发生过的!

这段话,道出了软件工程最残酷的真相。

在现实的商业世界中,代码被“读”的次数,远远大于被“写”的次数。我们今天为了“炫技”和“偷懒”而引入的复杂抽象,在未来都会变成自己或同事头上高悬的达摩克利斯之剑。

Go 语言的伟大之处,不在于它提供了多么强大的功能,而在于它用编译器级别的强制力,物理切断了程序员走向过度设计的退路。

它就像一个严肃的教练,时刻在你耳边咆哮:

  • “别搞继承了,给我用组合!”
  • “别提前抽象了,等你复制了三遍同样的逻辑再去重构!”
  • “别隐藏错误了,给我老老实实写 if err != nil !”

正如评论区那句精辟的总结:“Java 教会了我抽象,而 Go 教会了我停止抽象。”

小结

最好的工具,永远是那个不会在你偶尔一拍脑袋想炫技时,配合你演出的工具。

当我们褪去年轻时对各种花哨设计模式的盲目崇拜,回归到用代码解决商业问题的本质时,你会发现,Go 语言那看似平庸的“笨拙”,正是它能撑起云原生时代半壁江山的终极底气。

在这个大模型开始疯狂自动生成代码的时代,Go 那种一眼望到底的清晰逻辑,更将成为人类审查 AI 代码时,最坚固的一道防线。

简单,才是不可被轻易击败的复杂。

资料链接:https://www.reddit.com/r/golang/comments/1t9fyfp/go_is_the_language_that_finally_made_me_stop/


今日互动探讨:

在你的编程生涯中,你有没有写过让你后来自己看都觉得“用力过猛”的过度设计代码?你觉得 Go 语言这种强行压制抽象的设计哲学,是保护了团队,还是扼杀了创造力?

欢迎在评论区分享你的血泪史与感悟!


还在为写 Agent 框架频频死循环、上下文爆炸而束手无策?我的新专栏 从0 开始构建 Agent Harness 将带你:

  • 抛弃臃肿框架,回归“驾驭工程 (Harness Engineering)”的第一性原理
  • 用 Go 语言手写 ReAct 循环、并发拦截与上下文压缩引擎等,复刻极简OpenClaw
  • 构建坚不可摧的 Safety Middleware 与飞书人工审批防线
  • 在底层实现 Token 成本审计、链路追踪与自动化跑分评估
  • 从“调包侠”进化为掌控大模型边界的“AI 操作系统架构师”

扫描下方二维码,开启从 0 开始构建Agent Harness 的实战之旅。


原「Gopher部落」已重装升级为「Go & AI 精进营」知识星球,快来加入星球,开启你的技术跃迁之旅吧!

我们致力于打造一个高品质的 Go 语言深度学习AI 应用探索 平台。在这里,你将获得:

  • 体系化 Go 核心进阶内容: 深入「Go原理课」、「Go进阶课」、「Go避坑课」等独家深度专栏,夯实你的 Go 内功。
  • 前沿 Go+AI 实战赋能: 紧跟时代步伐,学习「Go+AI应用实战」、「Agent开发实战课」、「Agentic软件工程课」、「Claude Code开发工作流实战课」、「OpenClaw实战分享」等,掌握 AI 时代新技能。
  • 星主 Tony Bai 亲自答疑: 遇到难题?星主第一时间为你深度解析,扫清学习障碍。
  • 高活跃 Gopher 交流圈: 与众多优秀 Gopher 分享心得、讨论技术,碰撞思想火花。
  • 独家资源与内容首发: 技术文章、课程更新、精选资源,第一时间触达。

衷心希望「Go & AI 精进营」能成为你学习、进步、交流的港湾。让我们在此相聚,享受技术精进的快乐!欢迎你的加入!

img{512x368}


商务合作方式:撰稿、出书、培训、在线课程、合伙创业、咨询、广告合作。如有需求,请扫描下方公众号二维码,与我私信联系。

AI 时代,软件大师们为什么都倒戈向 Go 和 Rust 了?

本文永久链接 – https://tonybai.com/2026/05/14/uncle-bob-esr-on-why-we-are-turning-to-go-and-rust-in-the-ai-era

大家好,我是Tony Bai。

在软件工程的浩瀚星河中,有两位堪称“活化石”级别的宗师:

一位是 Eric S. Raymond (ESR),开源运动的先驱,那本被誉为开源圣经的《大教堂与集市》以及《Unix编程艺术(The Art of UNIX Programming)》一书均是出自他手。他是一个写了 40 年 C 语言的硬核黑客。

另一位是 Uncle Bob Martin (Bob 大叔),敏捷宣言的签署人之一,《敏捷软件开发》、《代码整洁之道 (Clean Code)》等程序员经典书籍的作者,无数 Java 和 C# 程序员的精神导师。

这两位加起来写了快一百年代码的传奇人物,最近却在 X (Twitter) 平台上,不约而同地抛出了一个足以引发技术圈大地震的论断:

在如今这个被 AI 席卷的时代,他们双双放弃了自己曾经最擅长的语言(C 和 Java),转而全面拥抱 Go 语言,并在特定底层场景下使用 Rust。

更令人震撼的是,ESR 直接宣告了手工古法编程模式的死刑:

“手写代码的时代基本结束了(The age of hand-coding is mostly over)。现在选择编程语言的标准,已经彻底变了。”

今天,我们就来深度扒开这场顶级黑客的“赛博夜话”,看看在 AI 智能体(Agent)狂飙突进的 2026 年,我们究竟该如何重新审视和选择我们手中的“兵器”。

认知颠覆:当 AI 成为主程序员,语言的选择标准变了

我们过去是如何选择编程语言的?

语法是否优雅?生态是否繁荣?框架是否齐全?这些都是基于“人类如何高效手写代码”而设定的标准。

但 ESR 尖锐地指出,在如今我们拥有“机器朋友(Robot friends / AI)”来完成绝大部分代码生成和翻译工作的时代,这些旧标准已经失效了。

现在的核心标准只有两个:

1. 你的 AI 朋友,能不能高质量地生成这种语言的代码?
2. 生成之后,作为人类的你,能不能一眼看懂(Review)这些代码?

“如今,我使用什么计算机语言是否顺手,已经不再那么重要了,真正重要的是我正在使用的‘机器朋友’能否高质量地生成它。
同时也重要的是我能否读懂这门语言,因为我需要亲自去审查(Review)这些代码。”

在这个新标准下,那些充满了黑魔法(如各种奇葩的宏、复杂的继承体系、极度隐晦的元编程)的语言,瞬间成了灾难。因为当 AI 吐出几百行充满魔法的代码时,人类审查的“认知负荷”将是灾难性的。

宗师的抉择:为什么是 Go 和 Rust?

在这个全新的游戏规则下,两位宗师给出了他们惊人一致的答案。

Bob 大叔的 Go 语言初体验:快、无聊、但完美契合 AI

Bob 大叔在评论区透露,他正在设计一门关于“使用 Agent 进行软件工程”的在线课程。

“在过去,我会选择像 Java、C# 或 JavaScript 这样流行的语言来做课程。但这次我选择了 Go。不是因为它流行,而是因为它很快(Fast)。我的学生们不会花太多精力去钻研 Go 的语法细节,但他们会看到 Go 的表现。”

Go 语言那常被诟病的“啰嗦”和“无聊”,在 AI 时代反而成了最强大的护城河。

因为 Go 的语法极度收敛,没有隐式类型转换,没有复杂的泛型继承。当 AI 生成一段 Go 代码时,那满屏极其直白的 if err != nil,让人类工程师一眼就能看穿它的逻辑底裤。在审查 AI 代码时,没有魔法,就是最高的生产力。

ESR 的决断:别了,我写了 40 年的 C 语言

ESR 的话更具传奇色彩和悲壮感:

“我可能再也不会用 C 语言开新项目了。那除了自虐还有什么意义?我花了 40 年写 C,我非常精通。但我会毫不留恋地把它,连同它的缓冲区溢出、堆破坏、未定义行为和可移植性问题,全部抛在脑后。”

他现在的探索性编程,全部交给了 Python 或 Go。

“我的机器朋友在生成这两种语言的代码时都非常出色。我认为它们在生成 Go 代码时的表现甚至略胜一筹,这可能是因为 Go 语言拥有更小的表面积(smaller surface)。

(注:Smaller surface 意味着语法简单,AI 预测下一个 Token 时的歧义和错误率极低)

至于 Rust,ESR 将其定位为“终极的降落场”。

当他需要极其坚固的内存安全保证,且代码的探索期已经结束,进入严肃的生产部署阶段时,他会让 AI 把代码翻译成 Rust。

“Rust 满足了我的要求——我发现它写起来很麻烦,但读起来基本没问题。”

时代的阵痛:被 AI 降维打击的传统生态

这场讨论,不仅是对 Go 和 Rust 的赞歌,更是对一些传统“大厂语言”的残酷揭底。

ESR 毫不客气地吐槽了 Python 曾经的混乱(尽管它现在有了类型提示和 uv 等现代工具,情况有所好转):

“Python 曾是我的最爱,但在 Python 2 到 Python 3 的灾难性过渡、GIL 导致的并发地狱、以及包管理的混乱之后,我曾对它感到厌倦……如果我现在要写一个比 Python 粘合脚本大得多的东西,我只会耸耸肩,然后直接去用 Go。”

在推特的评论区,另一位开发者的一句话,道出了更多人的心声:

“Go 代码的质量,很大程度上是因为 Go 语言本身往往倾向于极高的质量(因为缺乏炫技的空间)。所以 AI 生成的代码,也顺理成章地继承了这种高质量。”

当一门语言为了迎合人类的“偷懒”和“炫技”而变得越来越复杂时(比如不断叠加新特性的 C++ 和 Java),它在 AI 时代反而会成为一种累赘。

因为 AI 不需要语法糖,AI 需要的是绝对的清晰和确定性。

反思:从“写手”到“审查员”的身份跃迁

两位古灰级黑客的这番言论,给所有还在为了“哪种语言的特性更酷炫”而争得面红耳赤的年轻程序员,狠狠地上了一课。

时代的列车已经呼啸而过。

当代码生成不再是瓶颈,软件工程师的核心价值,正在不可逆转地从“Writer(编写者)”向“Reader & Reviewer(阅读者与审查者)”迁移。

在这个新时代,我们评估一项技术的眼光必须升级:

  1. 可审计性(Auditability)大于一切:如果一段代码极其简洁但难以调试,它就是垃圾。Go 语言的“直白”,在 AI 时代成为了最顶级的安全感。
  2. 安全性的底座转移:像 Rust 这样通过极其严苛的编译器来保证内存安全的语言,将成为 AI 时代最可靠的“数字基础设施钢筋”。你可能不需要手写它,但你的 Agent 会为你生成它,并由编译器确保它不会在半夜崩溃。
  3. 拥抱“机器思维”:放下程序员的“文人相轻”,接受那些对机器友好、对审查友好的“无聊技术”。

小结:向宗师致敬,向未来前行

如果连写了 40 年 C 语言的 Eric S. Raymond,和开创了现代软件工程思维的 Uncle Bob,都能毫不犹豫地放下过去的骄傲,全身心地拥抱 AI、Go 和 Rust。

我们这些普通开发者,还有什么理由紧抱着那些陈旧的“鄙视链”不放呢?

手写代码的时代正在落幕,但软件工程的黄金时代,才刚刚开始。

用 Go 来快速验证和构建业务,用 Rust 来打造坚不可摧的底层,让 AI 成为那个不知疲倦的打字员。这,就是顶级黑客们为我们指明的 2026 年生存法则。

资料链接:https://x.com/esrtweet/status/2054288478750597593


今日互动探讨:

连 Bob 大叔和 ESR 都倒戈了!你同意他们“手写代码时代已结束”、“更看重代码审查的可读性”的观点吗?在日常的 AI 辅助编程中,你觉得哪种语言的体验最好?

欢迎在评论区分享你的看法!


还在为写 Agent 框架频频死循环、上下文爆炸而束手无策?我的新专栏 从0 开始构建 Agent Harness 将带你:

  • 抛弃臃肿框架,回归“驾驭工程 (Harness Engineering)”的第一性原理
  • 用 Go 语言手写 ReAct 循环、并发拦截与上下文压缩引擎等,复刻极简OpenClaw
  • 构建坚不可摧的 Safety Middleware 与飞书人工审批防线
  • 在底层实现 Token 成本审计、链路追踪与自动化跑分评估
  • 从“调包侠”进化为掌控大模型边界的“AI 操作系统架构师”

扫描下方二维码,开启从 0 开始构建Agent Harness 的实战之旅。


原「Gopher部落」已重装升级为「Go & AI 精进营」知识星球,快来加入星球,开启你的技术跃迁之旅吧!

我们致力于打造一个高品质的 Go 语言深度学习AI 应用探索 平台。在这里,你将获得:

  • 体系化 Go 核心进阶内容: 深入「Go原理课」、「Go进阶课」、「Go避坑课」等独家深度专栏,夯实你的 Go 内功。
  • 前沿 Go+AI 实战赋能: 紧跟时代步伐,学习「Go+AI应用实战」、「Agent开发实战课」、「Agentic软件工程课」、「Claude Code开发工作流实战课」、「OpenClaw实战分享」等,掌握 AI 时代新技能。
  • 星主 Tony Bai 亲自答疑: 遇到难题?星主第一时间为你深度解析,扫清学习障碍。
  • 高活跃 Gopher 交流圈: 与众多优秀 Gopher 分享心得、讨论技术,碰撞思想火花。
  • 独家资源与内容首发: 技术文章、课程更新、精选资源,第一时间触达。

衷心希望「Go & AI 精进营」能成为你学习、进步、交流的港湾。让我们在此相聚,享受技术精进的快乐!欢迎你的加入!

img{512x368}


商务合作方式:撰稿、出书、培训、在线课程、合伙创业、咨询、广告合作。如有需求,请扫描下方公众号二维码,与我私信联系。

如发现本站页面被黑,比如:挂载广告、挖矿等恶意代码,请朋友们及时联系我。十分感谢! Go语言第一课 Go语言进阶课 AI原生开发工作流实战 从 0 开始构建 Agent Harness Go语言精进之路1 Go语言精进之路2 Go语言第一课 Go语言编程指南
商务合作请联系bigwhite.cn AT aliyun.com
这里是 Tony Bai的个人Blog,欢迎访问、订阅和留言! 订阅Feed请点击上面图片

如果您觉得这里的文章对您有帮助,请扫描上方二维码进行捐赠 ,加油后的Tony Bai将会为您呈现更多精彩的文章,谢谢!

如果您希望通过微信捐赠,请用微信客户端扫描下方赞赏码:

如果您希望通过比特币或以太币捐赠,可以扫描下方二维码:

比特币:

以太币:

如果您喜欢通过微信浏览本站内容,可以扫描下方二维码,订阅本站官方微信订阅号“iamtonybai”;点击二维码,可直达本人官方微博主页^_^:
本站Powered by Digital Ocean VPS。
选择Digital Ocean VPS主机,即可获得10美元现金充值,可 免费使用两个月哟! 著名主机提供商Linode 10$优惠码:linode10,在 这里注册即可免费获 得。阿里云推荐码: 1WFZ0V立享9折!


View Tony Bai's profile on LinkedIn
DigitalOcean Referral Badge

文章

评论

  • 正在加载...

分类

标签

归档



View My Stats