Prompt进阶:9个月总结的核心工作流,让AI进入工程流程

Prompt进阶:9个月总结的核心工作流

让AI进入工程流程,而不是让它裸奔。


问题:你在帮AI还是在添乱?

大多数人用AI写代码的姿势:

  1. 输入需求
  2. 让它生成
  3. 报错了修一修
  4. 再生成
  5. 循环往复

结果:看似高效,实际埋坑。

一个忽略现有缓存层的函数,一个没考虑ORM规范的数据迁移,一个跟别处重复的API接口。这类错误安静、隐蔽,三个月后让整个系统雪崩。


核心心法:需求先工件化,执行先加护栏

一句话总结:让需求先变成工件,让代码只在护栏里改。

复制代码
❌ 帮我写个用户认证模块
✅ 先出方案,我审核通过后再写代码

三步工作流(经过9个月验证)

第一步:让AI先读懂

复制代码
帮我理解这个系统:
- 深入阅读src/目录下的代码
- 理解架构和数据流
- 复杂度、依赖关系、最容易出错的地方
把分析写进research.md,我确认后再下一步

关键:用"深入"、"细节"、"复杂度"这类词,告诉AI别走马观花。

第二步:写计划,反复标注修改

复制代码
基于对系统的理解,帮我出开发计划:
1. 要做什么
2. 改动哪些文件
3. 风险点在哪
4. 待实现的功能清单
写成plan.md

然后:在编辑器里直接往plan.md加注释:

  • 两个字的也有:"不可选"
  • 一段话的也有:解释某个业务约束,或者纠正架构方向

最后把文档扔回给AI

复制代码
我加了一些注释,按注释更新plan.md,先不要写代码。

第三步:一口气实现完

复制代码
全部实现。
完成一项就在plan.md里标记。
不到所有任务完成不要停。
持续运行类型检查。

进阶:OpenSpec工作流(来自真实项目验证)

对于真实生产项目,推荐用OpenSpec管理变更生命周期:

复制代码
/opsx:propose  → 需求拆解,产出proposal/design/tasks
      ↓
/opsx:apply   → 执行代码改动
      ↓
/opsx:verify → 核对实现是否和change工件对齐
      ↓
/opsx:archive → 归档,保持上下文干净

为什么这套流程重要?

阶段 问题 解决
propose 边界定义不清 先拆成工件,人审
apply AI自己扩需求 只做tasks.md范围内的事
verify 不知道改了什么 检查是否和工件对齐
archive 上下文越来越乱 归档保持干净

最佳实践:把"实现、评审、验证"彻底拆开

最危险的的不是AI写不出来,而是:

  • 它在没有边界的情况下乱改
  • 它不知道项目里的历史隐性约定
  • 它把实现、评审、验证混在一起
  • 它改完了代码,却没有把风险说清楚
  • 它碰到了SQL、配置、脚本这类高风险区域,却没有硬护栏

应该拆成不同职责:

职责 做什么
/opsx:verify 检查实现是否和OpenSpec对齐
prepare-review 整理这次改了什么,方便人review
spring-architecture-review 检查Spring分层有没有乱
sql-risk-review 检查SQL、批量更新的风险
reviewer 只读视角的代码审查

硬护栏:permissions + hooks

规则写进文档只是软约束,真正能拦住危险动作的,是权限和hook。

高风险目录(默认禁止修改):

  • src/main/resources/application*.yml
  • src/main/resources/db/
  • sql/
  • deploy/
  • secrets/

权限配置示例(~/.claude/settings.json):

json 复制代码
{
  "permissions": {
    "deny": [
      "sql/*",
      "deploy/*",
      "src/main/resources/application-prod.yml"
    ]
  }
}

Hook自动检查:

json 复制代码
{
  "hooks": {
    "BeforeWrite": [
      {
        "matcher": "*.sql",
        "command": "echo 'SQL变更需要人工审核'"
      }
    ]
  }
}

隐性约定要单独文档化

对真实业务项目来说,最危险的通常不是显式规则,而是那些"大家都知道,但没人写下来"的东西。

最佳实践:把所有容易导致"改完能跑、联调出错"的口头约定,单独沉淀到docs/implicit-contracts.md。

复制代码
例如:
- 单元详情接口里,前端依赖contentResponse做回显
- status = null 和 status = 0 在历史语义上并不等价
相关推荐
好家伙VCC2 小时前
**发散创新:基于Python与OpenCV的视频流帧级分析实战**在当前人工智能与计算机视觉飞速发展的背景下
java·人工智能·python·计算机视觉
lpfasd1232 小时前
Harness架构将成为AI工程的终极范式
人工智能·架构
xiaotao1312 小时前
阶段零:IDE选择 与 Jupyter Notebook / Lab 使用
ide·人工智能·python·jupyter
TDengine (老段)2 小时前
中原油田引入时序数据库 TDengine:写入性能提升、存储成本下降 85%
大数据·数据库·人工智能·时序数据库·tdengine·涛思数据
IT_陈寒2 小时前
SpringBoot里的这个坑差点让我加班到天亮
前端·人工智能·后端
财经资讯数据_灵砚智能2 小时前
基于全球经济类多源新闻的NLP情感分析与数据可视化(日间)2026年4月12日
大数据·人工智能·信息可视化·自然语言处理·ai编程
nix.gnehc2 小时前
实战部署|Ollama\+Qwen2\.5:3b\+Open WebUI 本地AI助手搭建全记录(附避坑指南)
人工智能·大模型·llm·ollama
FIT2CLOUD飞致云2 小时前
新增工作流类型工具,对话时可选择模型与知识库,MaxKB开源企业级智能体平台v2.8.0版本发布
人工智能·ai·开源·智能体·maxkb
code 小楊2 小时前
从开源折戟到闭源破局:Meta Muse Spark 全解析(含案例+调用指南)
人工智能·开源