标签 Go语言 下的文章

Go 语言之父亲自下场道歉:藏在 Spec 里的十年“笔误”,终于要修正了!

本文永久链接 – https://tonybai.com/2026/03/25/go-spec-contradiction-in-types-section

大家好,我是Tony Bai。

在 Go 语言的世界里,type 是我们每天都在打交道的关键字。但如果我今天问你一个极其基础的问题:

Go 语言内置的 bool 类型,到底是不是一个“Defined Type(已定义类型)”?

你可能会愣一下,然后不假思索地回答:“那必须是啊,bool 是语言自带的,当然是已定义的。”

但如果我再追问一句:“既然它是 Defined Type,为什么我们不能给它绑定方法,像 func (b bool) IsTrue() {} 这样写?”

你可能就彻底懵了。

别慌,如果你对这个问题感到困惑,说明你已经触及到了 Go 语言类型系统设计中最深、也最容易被忽视的一个“历史遗留问题”。

就在最近,Go 官方 GitHub 仓库中,一个看似在“抠字眼”的 Issue #78208(spec: contradiction in Types section) 引来了社区里多位Go开发者下场激烈辩论,最终甚至连 Go 语言三巨头之一、被誉为“Go 语言之父之一”的 Robert Griesemer 都亲自现身,发表了一段长文来“认错”,并用拉丁语写下了那句沉重的 “Mea culpa”(我的锅)

今天,我们就来当一次“技术侦探”,顺着这个 Issue 的蛛丝马迹,硬核扒开 Go 语言规范(Spec)的底层,看看这个小小的 bool 类型背后,到底藏着 Go 团队一段怎样的设计“原罪”,以及它对我们日常编码产生了多大的深远影响。

一段自相矛盾的官方“圣经”

故事的起因非常简单。一位开发者在精读 Go 语言官方规范(Spec,被誉为 Go 语言的“圣经”)时,发现了一个极其明显的逻辑矛盾。

Types 章节,规范明确地将“具名类型(Named types)”分为了三类:

“Predeclared types, defined types, and type parameters are called named types.”
(预声明类型、已定义类型和类型参数,统称为具名类型。)

这里的措辞,清晰地将这三者并列。

但当你翻到 Boolean types 章节时,却赫然写着:

“The predeclared boolean type is bool; it is a defined type.”
(预声明的布尔类型是 bool;它是一个已定义类型。)

矛盾爆发了!

如果“预声明类型”和“已定义类型”是平级的、不同的两个分类,那 bool 怎么可能既是前者,又是后者?这就像生物分类学里说“哺乳动物和爬行动物是不同的两个纲”,然后又说“老虎是一种爬行动物”一样荒谬。

这个问题瞬间在社区里炸开了锅。

一场关于“定义”的思辨

Issue 下方的评论区,堪称一场神仙打架。

一部分开发者认为这是明显的 Spec 笔误。他们旗帜鲜明地指出:

“bool 不是一个已定义类型。因为它不能拥有方法。对于一个已定义类型 T,它必须出现在 type T … 的定义中。”

这话说得掷地有声。我们都知道,type MyInt int 之后,MyInt 才是一个真正的 Defined Type,我们可以给它绑定方法。而 bool 显然不符合这个特征。

但另一派开发者,也开始了精彩的“诡辩”。他们认为:

“Spec 并没有说这三个分类是互斥的。‘预声明’只是意味着这个类型是编译器内置的,但它本质上依然是一个‘已定义’的类型。只不过它的定义对我们不可见罢了。”

双方你来我往,从类型的方法集,辩论到 Go 1.9 引入类型别名(Type Alias)时的历史背景,再到 Go 1.18 引入泛型后对“具名类型”的重新定义。

就在大家争得面红耳赤之时,Go 语言之父之一 Robert Griesemer 悄然现身,一锤定音。

Go 语言类型系统的“原罪”

Robert Griesemer 的长篇回复,像一本尘封已久的历史档案,为我们揭开了 Go 语言在类型设计上的一段“黑历史”。

他首先承认:“没错,你们都被搞糊涂了。这个 Spec 写得确实有歧义,我们马上就改。”

然后,他开始讲述这个“小小的”用词不当背后,隐藏的 Go 团队在设计类型系统时的“原罪”。

原罪的根源:Go 团队混淆了“拥有名字”和“拥有唯一身份”这两个概念。

  1. Go 1.0 时代

那时只有“具名类型”和“匿名类型”。为了让 int、bool 这些内置类型拥有独一无二的身份(Type Identity),Go 团队很自然地把它们也归入了“具名类型”,毕竟它们确实有名字。这在当时看起来很完美。

  1. Go 1.9 时代(引入类型别名)

type NewString = string 这样的类型别名出现了。NewString 也有名字,但它的身份和 string 是完全一样的。这就和原来的“具名=唯一身份”的假设冲突了。

为了解决这个问题,Go 团队做了一个现在看来极其糟糕的决定:他们把原来表示“唯一身份”的“具名类型”,改名为了 “已定义类型(Defined Type)”。而 bool、int 这些内置类型,为了保留它们的唯一身份,也就跟着一起被“定义”成了 Defined Type。

  1. Go 1.18 时代(引入泛型)

类型参数 T 出现了。T 也有名字,而且不同的类型参数(比如 T 和 P)必须拥有不同的身份。于是,Go 团队不得不又把“具名类型(Named Type)”这个概念重新捡了回来,这次用它来统称所有“拥有唯一身份”的类型。

看懂了吗?

bool 之所以被错误地描述为 defined type,完全是一次历史的意外。它是 Go 团队在不断给语言打补丁、修补旧概念的过程中,留下的一块“历史伤疤”。

Robert Griesemer 最后感慨道:“Mea culpa(我的锅)。”

这个小小的用词问题,背后是 Go 语言设计者在面对一个不断演进的复杂系统时,所做出的艰难权衡与无奈妥协。

他甚至自嘲般地补了一刀:

“为了让你们更受伤一点,我再告诉你们一个秘密:预声明的 any 类型,其实根本不是一个具名类型,它只是匿名接口 interface{} 的一个别名。”

最后,我们看到了Robert Griesemer 提交了一个cl,给出了修改方案:在spec中明确”predeclared types are named, not defined types”,即预声明类型是具名类型,但不是已定义类型。同时加上了对 any 这个预声明类型不是具名类型的澄清。

这个“抠字眼”的争论,对我们写代码有何意义?

看到这里,你可能会觉得:“搞了半天,不就是改几个英文单词吗?关我写业务代码什么事?”

关系太大了。理解了这段“黑历史”,你才能真正打通 Go 类型系统的任督二脉,尤其是在处理泛型和接口时。

1. 你才能真正理解“类型约束”的本质。

在泛型函数中,~string 这个约束,匹配的是所有底层类型为 string 的类型。它包含了 string 本身,也包含了 type MyString string 这种 Defined Type。

但如果你只写 string,那么 MyString 类型的变量是传不进去的。

因为 string 是“预声明类型”,而 MyString 是“已定义类型”,尽管底层结构一样,但它们的“身份”在 Go 的世界里是完全不同的。

2. 你才能彻底搞懂“方法集”的规则。

为什么 bool 不能有方法?因为它不是通过 type 关键字在你的代码里定义的。方法只能绑定在你明确定义的类型上。这个规则,是 Go 语言不允许你“污染”内置类型的安全护栏。

3. 你才能在写库时,做出更高级的 API 设计。

当你设计一个库的 API 时,到底是应该接受 string,还是应该接受 interface{ String() string }?

如果你只接受 string,那么所有基于 string 定义的新类型都必须强制转换,非常不便。

但如果你接受接口,就意味着你放弃了对底层数据结构的强约束。

理解了“预声明类型”与“已定义类型”在身份上的本质区别,你才能在这两者之间做出最合理的架构权衡。

小结:于细微处,见真章

一个看似吹毛求疵的 Issue,最终牵扯出了 Go 语言长达十几年的演进历史和设计哲学。

它告诉我们: 一门伟大的编程语言,并不是一蹴而就的天才设计,而是在无数次的妥协、修补和自我反思中,不断螺旋上升的有机生命体。

而我们作为开发者,对这门语言最好的尊重,就是不仅要知其然,更要知其所以然。

下次当你在面试中被问到 Go 的类型系统时,不妨把这个关于 bool 的故事讲给面试官听。相信我,这远比你背诵一百遍枯燥的语法规则,更能证明你对这门语言的深刻理解。

资料链接:

  • https://github.com/golang/go/issues/78208
  • https://go-review.googlesource.com/c/go/+/757120

今日互动探讨

在你的 Go 开发生涯中,遇到过哪些让你对 Go 的类型系统感到极其困惑,甚至怀疑人生的场景?比如类型断言的 panic、空接口的转换、还是泛型的约束?

欢迎在评论区分享你的踩坑经历!


还在为“复制粘贴喂AI”而烦恼?我的新专栏 AI原生开发工作流实战 将带你:

  • 告别低效,重塑开发范式
  • 驾驭AI Agent(Claude Code),实现工作流自动化
  • 从“AI使用者”进化为规范驱动开发的“工作流指挥家”

扫描下方二维码,开启你的AI原生开发之旅。


你的Go技能,是否也卡在了“熟练”到“精通”的瓶颈期?

  • 想写出更地道、更健壮的Go代码,却总在细节上踩坑?
  • 渴望提升软件设计能力,驾驭复杂Go项目却缺乏章法?
  • 想打造生产级的Go服务,却在工程化实践中屡屡受挫?

继《Go语言第一课》后,我的《Go语言进阶课》终于在极客时间与大家见面了!

我的全新极客时间专栏 《Tony Bai·Go语言进阶课》就是为这样的你量身打造!30+讲硬核内容,带你夯实语法认知,提升设计思维,锻造工程实践能力,更有实战项目串讲。

目标只有一个:助你完成从“Go熟练工”到“Go专家”的蜕变! 现在就加入,让你的Go技能再上一个新台阶!


原「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}


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

OpenAI 创始人盛赞 Rust,却遭开发者反驳:Go 才是大模型眼里的“香饽饽”!

本文永久链接 – https://tonybai.com/2026/03/23/go-is-the-best-programming-language-for-llm

大家好,我是Tony Bai。

在这个大模型重塑编程范式的当下,如果你想开发一个自主运行的智能体(Agent),或者想让大模型(LLM)帮你生成上万行的核心业务代码,你会选择哪门编程语言?

如果你去问 OpenAI 的总裁兼联合创始人 Greg Brockman,他的答案非常直接:

“Rust is a perfect language for agents, given that if it compiles it’s ~correct.”
(Rust 是开发 Agent 的完美语言,因为只要它能编译通过,它就基本是正确的。)

这句话听起来极其硬核且有道理。Rust 引以为傲的所有权模型和严苛的编译器,就像一个极度刻薄的审查员。既然大模型经常“胡言乱语”,那不如交给 Rust 编译器来兜底。

但有趣的是,Greg 的这番高论,最近在推特(X)上遭到了不少一线资深开发者的强烈反驳。其中,一条阅读量近 7 万的推文直指核心痛点,甚至抛出了一个让无数 Gopher(Go 开发者)极度舒适的反直觉结论:

“别吹 Rust 了,在大模型眼里,语法简单、风格统一的 Go 才是真正的‘香饽饽’!”

今天,我们就来扒一扒这场顶级“语言战争”背后的神仙打架,看看为什么 Go 语言身上那些曾经被全网群嘲的“缺点”,如今却成了大模型时代最无敌的护城河。

大模型写 Rust,真的安全吗?

发起反驳的开发者 Emil Privér 一针见血地指出了用大模型写 Rust 的最大陷阱:“逃课”心理

Greg Brockman 认为 Rust 编译器能阻止大模型犯错。但这有一个前提:大模型必须老老实实地去解生命周期(Lifetime)和所有权(Ownership)的方程。

然而现实是,大模型也是会“偷懒”的。

Emil 敏锐地指出,当现代 LLM 在生成复杂的 Rust 业务逻辑,且实在绕不过编译器的各种借用检查报错时,它们会极其鸡贼地使出大招:直接套上一层 unsafe {} 块,或者无脑使用 .unwrap() 来强行绕过编译器的安全审查!

你在指望编译器兜底,大模型却在底下悄悄开了“后门”。

就像评论区一位开发者吐槽的那样:“当你看到大模型为了图省事,把一段关键操作包在 unsafe 里,并且依然能顺利编译通过时,你还敢说它‘只要编译通过就基本正确’吗?”

虽然有开发者反驳说,可以通过配置强制禁止 unsafe。但大模型的“逃课手段”防不胜防,比如疯狂滥用 RefCell 导致运行时 Panic,这在编译器眼里是合法的,但在生产环境下却是灾难。

Go 的“无趣”,成了最顶级的生产力

既然 Rust 太“聪明”导致大模型容易弄巧成拙,那大模型到底喜欢什么样的语言?

Emil 给出的答案是:Go。

他的底层逻辑非常硬核。

他认为,大模型(LLMs)的本质是基于大量预训练语料进行下一个 Token 的概率预测。对于这种预测机制来说,一段代码的上下文看起来越“同质化(Looks the same)”,大模型生成的准确率就越高。

这就牵扯到了 Go 语言一个常年被群嘲的“缺点”:啰嗦、缺乏表现力、没有花里胡哨的语法糖。

在 Go 里,如果你想写一个循环,你只有一种办法:for 循环。

没有 while,没有 do-while,没有 foreach,更没有各种炫技的函数式流处理。

而在 Rust 或者 JavaScript 等语言里,你想遍历一个数组,至少有 5 种写法。甚至在不同的开源库里,大家的编码风格都千奇百怪。

在人类看来,Go 语言简直“无趣”到了极点。但在大模型这种无情的“概率预测机器”眼里,Go 简直就是天堂!

因为 Go 语言有着近乎暴君般的强制格式化工具 gofmt,以及全宇宙最少、最没有歧义的语法关键字。无论你是 Google 的顶级工程师,还是刚入门三个月的新手,写出来的 Go 代码结构几乎是一模一样的。

这种极度“收敛”和“无聊”的代码风格,恰恰完美契合了大模型的预测机制。

当所有的 Go 项目看起来都像是一个模子里刻出来的,大模型在生成上下文时就不需要去猜测“这个项目的主人喜欢用哪种流派”。它闭着眼睛往下预测,准确率就能轻易碾压其他语言。

Go,这种“一眼望到底”的特性,让它成为了大模型眼里的头号“香饽饽”。

AI 时代的软件工程师,该选什么语言?

推特评论区里,争论依然在继续。

但透过这场口水战,我们作为一线的软件工程师,应该看透一个更深层次的时代演进:

在过去十年,程序员们热衷于发明各种奇技淫巧,比拼谁的代码写得更短、更具“魔法”;但在未来,当 80%以上 的代码都将由 AI Agent 自动生成时,“可读性”与“无歧义”将成为一门编程语言最核心的生产力。

Go 语言的联合缔造者 Rob Pike 当年顶着巨大的压力,坚持不给 Go 加各种复杂的特性。很多人觉得他固执、老派。但在十多年后的今天,当大模型海啸席卷而来时,我们才突然惊觉:

Go 语言那种“强迫你用最笨、最直白的方式写代码”的设计哲学,不仅让它在微服务时代大杀四方,更让它在 AGI 时代,成为了大模型最忠实、最可靠的合作伙伴。

当大模型吐出一段复杂的 Rust 代码,你可能还要花十分钟去审查它有没有隐藏的逻辑陷阱;

但当大模型吐出一段 Go 代码,那满屏极其直白的 if err != nil,让人类工程师一眼就能看穿它的核心逻辑。

没有魔法,才是大模型时代最强的防御。

资料链接:https://x.com/emil_priver/status/2034971247348535399


今日互动探讨:

在日常开发中,你让 ChatGPT/Claude 帮你写过哪种语言的代码?你觉得它写 Go、Python 还是 Rust 时的准确率最高?

欢迎在评论区分享你的实战感受!


还在为“复制粘贴喂AI”而烦恼?我的新专栏 AI原生开发工作流实战 将带你:

  • 告别低效,重塑开发范式
  • 驾驭AI Agent(Claude Code),实现工作流自动化
  • 从“AI使用者”进化为规范驱动开发的“工作流指挥家”

扫描下方二维码,开启你的AI原生开发之旅。


你的Go技能,是否也卡在了“熟练”到“精通”的瓶颈期?

  • 想写出更地道、更健壮的Go代码,却总在细节上踩坑?
  • 渴望提升软件设计能力,驾驭复杂Go项目却缺乏章法?
  • 想打造生产级的Go服务,却在工程化实践中屡屡受挫?

继《Go语言第一课》后,我的《Go语言进阶课》终于在极客时间与大家见面了!

我的全新极客时间专栏 《Tony Bai·Go语言进阶课》就是为这样的你量身打造!30+讲硬核内容,带你夯实语法认知,提升设计思维,锻造工程实践能力,更有实战项目串讲。

目标只有一个:助你完成从“Go熟练工”到“Go专家”的蜕变! 现在就加入,让你的Go技能再上一个新台阶!


原「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