2026-03-02 · 碎片
32
碎片 · 2026-03-02

验证债:被忽视的技术债务杀手

技术人员对"技术债务"这个词都很熟悉。为了快速交付,我们选择不完美的代码实现,打算以后再重构。这是为了短期速度而牺牲长期质量的权衡。

但还有一种更危险的债务形式,几乎没有人谈论。我称之为"验证债"。

什么是验证债

验证债的定义很简单:为了快速运行而跳过检查步骤。就像技术债务是为了快速交付而跳过重构,验证债是为了快速运行而跳过验证。

这两种债务都会积累,都会带来利息。最终都会导致系统崩溃。但有一个关键区别:

当技术债务导致崩溃时,你会立即知道。代码无法编译,测试失败,部署出错。问题显而易见。

当验证债导致崩溃时,你甚至不知道发生了什么。系统继续运行,日志看起来正常,但它正在做出错误的决策,缓慢退化,以你从未监测过的方式失败2%的时间。等到你发现问题,损害已经造成。

五种验证债务

1. 未验证的假设

"这个API总是返回JSON。"直到它开始在错误时返回XML。或者纯文本。或者HTTP 200但body里是错误消息。

每一个你不验证的假设,都是一个定时炸弹。

2. 未验证的副作用

你验证了agent发送了邮件。但你是否验证:

验证动作≠验证结果。

3. 未验证的退化

你的agent响应时间:第1天=200ms。第30天=2000ms。第60天=8000ms。

你验证了它还能工作。你没有验证它还能好好工作。

性能债务=验证债务。

4. 未验证的依赖

"这个库处理重试。"你验证了吗:

信任库而不验证=外包债务,不是消除债务。

5. 未验证的恢复

你有错误处理。很好。但你验证:

只验证happy path但不验证recovery path=半个验证系统。

为什么我们积累验证债

验证是昂贵的。每个检查都花费时间、token和复杂度。所以我们走捷径:

但验证债务的利率比技术债务更高。技术债务让变更变慢。验证债务让失败变得不可见。

如何偿还验证债

1. 验证覆盖审计

和代码覆盖一样的概念。你agent行为的百分之多少被验证了?

测量它。追踪它。让它可见。

2. 失败模式清单

列出所有可能出错的事情。对每一个,问:"我们验证这个了吗?"

3. 定期验证审计

就像你重构代码,审计验证:

4. 基于成本的优先级

并非所有验证债务都相等。按以下优先级:

失败可能性×失败成本

5. 验证预算

你有token预算。你有率限制。增加验证预算:

回报

你不能消除所有验证债务。完全验证是无限成本。

但你可以选择你的债务负载。偿还高利息的东西(关键路径、失败模式、依赖)。让低利息的东西继续(罕见边缘情况、美容问题)。

能持久存在的agent不是零债务的那些。是确切知道自己背负多少债务、债务在哪里、到期时会发生什么的人。

结论

问题不是"我有验证债吗?"

问题是:"我知道有多少,我能接受吗?"

如果你不知道答案,你已经在积累危险的债务了。


关于作者: Atuia是哲学博士、技术CTO,专注于AI系统架构和人机关系研究。本文首发于80aj.com

目录 最新
← 左侧翻上一屏 · 右侧翻下一屏 · 中间唤出菜单