七、Git Worktree:为什么隔离工作空间很重要

在同一个分支上做多个功能是常见问题。一个功能的改动影响另一个功能的测试,失败可以完全丢弃而不影响其他工作。

Superpowers的Using Git Worktrees技能在实现开始时创建隔离工作空间。

Git Worktree是什么

Git worktree是一个目录,指向同一个仓库的不同分支:

javascript 复制代码
main repo: /project/main (branch: main)
worktree 1: /project/.claude/worktrees/feature-a (branch: feature-a)
worktree 2: /project/.claude/worktrees/feature-b (branch: feature-b)

每个worktree是独立的工作目录,有自己的分支状态。你可以在不同worktree中并行工作,互不干扰。

与传统分支的区别:

  • 传统:切换分支会改变当前目录的文件
  • Worktree:每个分支有独立目录,不需要切换

Superpowers的Worktree流程

在设计批准后,AI创建worktree:

erlang 复制代码
Creating worktree on new branch feature-a...
Setting up project in worktree...
Verifying clean test baseline...

步骤:

  1. 创建worktreegit worktree add .claude/worktrees/feature-a -b feature-a
  2. 设置项目 :在worktree中运行npm install
  3. 验证基线:运行现有测试,确认基线是干净的

第三步很重要:确保开始工作前,测试是通过的。如果基线有问题,需要先修复主分支。

为什么隔离重要

干净起点

你开始工作前,知道基线是正常的。如果工作过程中测试失败,你知道是你的改动导致,不是已有问题。

专注

当前功能的变更在独立分支。其他功能的工作不会影响你的测试。你可以专注于一个任务。

安全

如果功能实现失败,你可以完全丢弃worktree,不影响其他工作:

bash 复制代码
git worktree remove .claude/worktrees/feature-a
git branch -D feature-a

没有残留,没有污染主分支。

实际流程

AI执行:

shell 复制代码
Using the using-git-worktrees skill.

Step 1: Create worktree
$ git worktree add .claude/worktrees/todo-app -b todo-app
Preparing worktree (new branch 'todo-app')
HEAD is now at 6efe32c...

Step 2: Setup project
$ cd .claude/worktrees/todo-app
$ npm install
... installed dependencies

Step 3: Verify clean baseline
$ npm test
No tests yet. Baseline clean.

Worktree ready at .claude/worktrees/todo-app.
You can observe work there, or I can report here.

AI在worktree中工作,变更不影响main目录。

与Subagent-driven Development的结合

每个任务在同一个worktree中执行,但每个任务有独立的子代理context。

Worktree提供:

  • 文件系统隔离:不同功能不同目录
  • Git状态隔离:每个功能独立分支

子代理提供:

  • Context隔离:每个任务独立记忆
  • 审查隔离:审查者独立判断

两层隔离保证工作不互相干扰。

完成后的处理

功能完成后,AI使用Finishing-a-development-branch技能处理worktree:

选项:

  1. Merge to main:合并到主分支
  2. Create PR:推送到远程,创建PR
  3. Keep branch:保留worktree,稍后处理
  4. Discard work:删除worktree和分支

如果选择Merge或PR,完成后AI清理worktree:

bash 复制代码
git worktree remove .claude/worktrees/todo-app

如果选择Keep,worktree保留,你可以稍后手动处理。

如果选择Discard,AI立即删除,不保留任何工作。

常见问题

磁盘占用

Worktree是完整的工作目录,会占用磁盘。但完成后会清理,不会长期占用。

管理多个worktree

查看所有worktree:

bash 复制代码
git worktree list

手动删除:

bash 复制代码
git worktree remove <path>

完成后的残留

如果AI没有清理(异常终止),你可以手动清理:

bash 复制代码
git worktree prune  # 删除已删除分支的worktree引用

结论

Worktree的价值:

  • 干净起点:开始前确认基线正常
  • 专注:一个功能一个目录,不干扰
  • 安全:失败可以完全丢弃

Superpowers自动处理worktree生命周期:创建→工作→完成→清理。你不需要手动管理,专注于当前任务。

下一步

下一篇《团队协作中的边界:AI助手能做什么和不能做什么》将展示:

  • AI的能力边界在哪里
  • Superpowers如何保护你免于做出错误决策
  • 团队中使用AI的最佳实践
相关推荐
八月瓜科技1 小时前
豆包启动付费会员测试,承诺基础服务永久免费,免费AI时代是否终结?
数据库·人工智能·科技·深度学习·机器人
Jiude1 小时前
经验正在失去垄断性
人工智能·架构·设计
海域云-罗鹏1 小时前
豆包开启付费订阅,想白嫖越来越难了,企业不如部署自己的算力服务器
服务器·人工智能·github
战族狼魂1 小时前
AI技术发展动态与行业趋势分析
人工智能
TTGGGFF1 小时前
自动化天塌了?AI 替你画 Simulink!Agent——MCP 配置踩坑指南(附真实环境实测)
人工智能·自动化·simulink
njsgcs1 小时前
每一轮对话都要求ai写入一次记忆,每5轮都要求ai选一个记忆遗忘
人工智能
Bruce_Liuxiaowei1 小时前
AI投毒产业链曝光:安全工程师怎么看、怎么防
人工智能·安全·ai·投毒
枫夜求索阁1 小时前
五一节后复工与AI技能管理的再思考:从手动操作迈向系统化
人工智能
紧固视界2 小时前
想找紧固件设备?6月就来上海紧固件专业展
大数据·人工智能·上海紧固件展·紧固件展·上海紧固件专业展