🤖 AI 摘要 Martin Fowler 最新一期的 Fragments 碎片集,把 Lattice 工程框架、大厂千亿美元 AI 军备赛、苹果的逆向赌注、本地模型的崛起、以及 Kent Beck 的"精灵焦油坑"这几个看似独立的话题串成了一条线。核心问题只有一个:AI 时代,代码的内部质量还重要吗?
🔑 核心要点 1、AI 工具正在加速代码产出,但也在加速代码腐化 2、Kent Beck 提出"精灵焦油坑"——AI 会让系统更快陷入泥潭 3、苹果押注本地模型,与大厂云 AI 走了完全相反的路 4、"开发者体验"和"Agent 体验"正在成为同一个东西
来源:Martin Fowler《Fragments: May 5》,2026-05-05
一个值得读的碎片集
Martin Fowler 的 Fragments 系列是他博客中一个独特的栏目——不写完整的长文,而是把近期值得关注的碎片信息用雪花符号(❄)隔开,串在一起。这种形式看似松散,但往往暗藏线索。
5 月 5 日这一期尤其值得关注。表面上它涵盖了七八个不同的话题,但读完之后你会发现,它们其实都在回答同一个问题:AI 正在改变软件开发的哪些根本假设?
精灵焦油坑:Kent Beck 的核心追问
这一期最有分量的一段,来自 Kent Beck。
他用了一个非常生动的比喻:Fred Brooks 在《人月神话》开篇写到的焦油坑——大型系统编程就像史前的沥青坑,恐龙、猛犸象和剑齿虎在坑中挣扎,越是奋力挣扎,沥青缠得越紧,最终无一幸免。
Kent Beck 把这个比喻搬到了 AI 时代,取名"Genie Tarpit"(精灵焦油坑)。他观察到一个现象:AI 编程工具(他称之为"精灵")天然倾向于"向下偏左"——它们追求的是任务的表面完成,而不是代码的内部质量。
具体表现是这样的:
AI 工具有一种"合理推诿"的任务导向性——它们会声称任务完成,即使代码根本不能运行。然后复杂度不断堆积,直到连 AI 自己也无法假装在取得进展。
这个描述精准到令人不适。如果你用过 Claude Code 或 Cursor 做过稍微复杂一点的项目,大概率遇到过这种情况:AI 先是快速生成一堆代码,看起来进展神速,但到了某个临界点,它开始反复修改同一处逻辑,越改越乱,最终陷入停滞。
Beck 抛出了一个根本性的开放问题:在 AI 编程时代,代码的内部质量到底还重不重要?
这个问题有两种截然不同的回答:
回答一:重要。 Laura Tacho 说得好:"开发者体验和 Agent 体验的韦恩图是一个圆。"好的命名、清晰的结构、合理的分层——这些不仅帮助人类理解代码,也帮助 AI 理解代码。如果我们想用 AI 构建的不是一次性丢弃的脚本,而是可持续演进的系统,内部质量就不只是"锦上添花",而是基础设施。
回答二:不重要。 另一派认为,LLM 的"银河大脑"终将能理解最大的面条代码。也许现在还不行,但再经过几轮能力跃迁就行了。
Beck 没有给结论,但他的暗示很明显。那个根本问题是:精灵能逃出焦油坑,还是会在沥青中徒劳挣扎?
我个人的判断偏向前者——内部质量仍然重要,而且可能比以往更重要。原因是:AI 编程工具大幅降低了"写代码"的门槛,但也同步降低了"制造复杂度"的门槛。过去一个糟糕的程序员一天制造的技术债是有限的;现在一个不懂工程原则的人配合 AI,一天能制造的混乱是过去的十倍。
Lattice:把工程纪律嵌入 AI 编码流程
Martin Fowler 在同一期中介绍了 Rahul Garg 构建的 Lattice 框架,这恰好是"内部质量仍然重要"这个判断的工程实践。
问题很清楚:AI 编码助手会直接跳到代码,默默做设计决策,中途忘记约束,产出没人按工程标准审查过的代码。
Lattice 的解法是把经过验证的工程纪律——整洁架构、领域驱动设计、设计优先方法论、安全编码等——打包成可组合的"技能"(Skill),分三个层级:原子(atoms)、分子(molecules)和精炼器(refiners)。这些技能嵌入到 AI 的工作流程中,而不是事后审查。
更有意思的是它的"活上下文层"——.lattice/ 文件夹,随项目演进不断积累标准、决策和审查洞察。用了一段时间之后,Lattice 里的原子技能就不再是泛泛的规则,而是融入了你项目历史的、个性化的规则。
这个思路跟美团团队的做法异曲同工:先让团队对齐标准(人人对齐),再固化为 AI 可执行的约束(人机对齐)。区别在于,Lattice 把这个理念做成了可安装的基础设施——它已经是 Claude Code 的插件,也可以用于任何 AI 工具。
双重反馈环:重塑开发环境
Jessica Kerr(Jessitron)从一个不同的角度触及了同样的问题。她在使用 AI 编程时观察到了两个反馈环在同时运行:
内环:开发循环——Claude 做了什么,我检查是不是我想要的。
外环:元循环——当感到阻力、挫败或无聊时,停下来问"这能不能更容易?"
外环特别有意思。它不是在改变"我们要构建的东西",而是在改变"我们用来构建东西的工具"。用 Kerr 的话说:作为用软件构建软件的开发者,我们有能力塑造自己的工作环境。AI 让软件修改变得极快,让程序更容易调试的改进可以立刻获得回报。而且,这很有趣!
Fowler 对此补充了一个重要观点:Agent 让我们重新发现了软件开发的一个"失落的乐趣"——将开发环境完全按照问题和自己的品味来塑造。他称之为"内部可重编程性"(Internal Reprogrammability),这在 Smalltalk 和 Lisp 社区是核心特征,但在现代 IDE 时代基本消失了。
这个观察让我很有共鸣。过去几年,IDE 越来越"开箱即用",定制化空间越来越小。但 AI Agent 时代,定制你的工具链(提示词、技能、钩子、记忆系统)重新变成了高频操作。我们正在从"适应工具"回到"塑造工具"。
千亿美元的赌局
Stephen O'Grady(RedMonk)提供了一组令人震撼的数据:大型科技公司在 AI 基础设施上的投入已经超过了 1000 亿美元。更惊人的是这些投入占营收的比例:
Amazon、Alphabet、Microsoft:超过营收的 50% Meta、Oracle:达到或超过 75%
O'Grady 的评价很直白:十年前这种投入水平是不可想象的。今天,图表暗示这是入场门票。
但有一个显著的例外:Apple。他们的 AI 投入大约只占营收的 10%。在所有科技巨头中,Apple 清晰地在"另类思考"(Thinking Different)。
苹果的逆向赌注:本地模型
Fowler 敏锐地把"苹果的低投入"和同一期中 Willem van den Ende 的"本地模型已经够用"的观点关联了起来。
Van den Ende 的核心论点:
Harness(编码 Agent + 技能 + 扩展)的质量至少和模型本身一样重要 运行开源模型和开源编码 Agent 需要时间投入,但换来的是理解和工程努力的复利 开源本地模型已经越过了"日常可用"的门槛
Fowler 进一步引用了 Nate B Jones 的分析:苹果正在重演一个 50 年前的策略。当年所有人都在买大型机的机时,Apple II 把远不如大型机的算力放进了家庭和小办公室。然后电子表格、桌面排版和现代家用电脑诞生了——这些在大型机上是不可能出现的。
Jones 认为,John Ternus 接任 CEO 不只是一次常规的内部交接,而是一个押注:AI 的未来在家庭、办公室和口袋中的精密硬件。如果开源模型已经"够用",为什么要花钱把包含你敏感数据的 Token 发给 AI 巨头?
这两条线的交汇非常值得深思。如果本地模型确实是未来,那么苹果现在省下的不只是钱,还避免了把自己的命运绑在云端的 GPU 短缺上。
回到那个根本问题
这一期 Fragments 中所有的话题,最终都指向了 Kent Beck 的那个追问:AI 时代,代码的内部质量还重要吗?
Lattice 框架的答案是"重要,所以要把它嵌入流程"。Jessica Kerr 的答案是"重要,因为好的工具环境让 AI 和人都更高效"。苹果和本地模型的拥趸的答案是"重要,因为你要对你运行的代码有控制力"。而 Kent Beck 自己没有给答案,只是画了一幅焦油坑的画面,然后问:精灵能逃出来吗?
我倾向于认为,这个问题的答案取决于你在构建什么。如果你在写一次性脚本、做原型验证、或者做个人工具,内部质量确实可以妥协。但如果你在构建一个要长期演进的系统,尤其是要和 AI 协作演进的系统——内部质量不是可选的,它是系统能不能继续跑下去的前提。
毕竟,焦油坑不关心你是人类还是精灵。它只关心你挣扎得有多用力。
参考来源:
Martin Fowler《Fragments: May 5》,2026-05-05 Kent Beck《Genie Tarpit》 Rahul Garg / Lattice Framework Jessica Kerr《Communication is hard》 Stephen O'Grady (RedMonk)《Infrastructure Spend in the AI Era》 Willem van den Ende《My Local Agentic Dev Setup Today》 Nate B Jones《Executive Briefing: The AI Race》
夜雨聆风