git 区分是 Git 分支还是 worktree 路径名

分支:worktree-agent-a4bc263f9c9ca0cda

对应 worktree:.claude/worktrees/agent-a4bc263f9c9ca0cda

既是分支 worktree-agent-a4bc263f9c9ca0cda,也绑定了一个 worktree

可以这样区分:

1. 看它是不是 Git 分支

bash 复制代码
git branch --list "*worktree-agent-a4bc263f9c9ca0cda*"

如果有输出,比如:

text 复制代码
+ worktree-agent-a4bc263f9c9ca0cda

说明它是一个 Git 分支。

前面的 + 表示:这个分支当前被某个 worktree 使用中,所以不能直接 git branch -D,必须先处理 worktree。

2. 看它是不是 worktree

bash 复制代码
git worktree list --porcelain

你之前的输出里有:

text 复制代码
worktree D:/phpstudy_pro/WWW/zhilin/aigc/aigc/.claude/worktrees/agent-a4bc263f9c9ca0cda
branch refs/heads/worktree-agent-a4bc263f9c9ca0cda

这表示:

  • worktree 路径是:.claude/worktrees/agent-a4bc263f9c9ca0cda
  • 它当前 checkout 的分支是:worktree-agent-a4bc263f9c9ca0cda

如何绑定的?

绑定关系是在创建 worktree 时产生的,例如:

bash 复制代码
git worktree add .claude/worktrees/agent-a4bc263f9c9ca0cda worktree-agent-a4bc263f9c9ca0cda

意思是:

text 复制代码
把分支 worktree-agent-a4bc263f9c9ca0cda
检出到目录 .claude/worktrees/agent-a4bc263f9c9ca0cda

从那一刻开始:

  • 这个目录就是一个 worktree
  • 这个分支就被该 worktree 占用
  • 主仓库里再看分支会出现 + 分支名
  • 删除分支前要先删 worktree:
bash 复制代码
git worktree remove .claude/worktrees/agent-a4bc263f9c9ca0cda
git branch -D worktree-agent-a4bc263f9c9ca0cda

一句话:分支是 Git 的指针,worktree 是实际工作目录;git worktree add <目录> <分支> 会把两者绑定起来。

相关推荐
小李不困还能学12 小时前
用git GUI往远程仓库中添加文件/文件夹
git
失途老马13 小时前
Git Patch 生成与应用完整操作手册
git
李白的天不白14 小时前
下载smartadmin框架
git·github
可乐要加冰^-^14 小时前
云雀文档下载
windows·git·github·石墨文档
NaclarbCSDN14 小时前
我写了一个命令行书签管理器,然后抛弃了浏览器书签栏
linux·git·python·github
++==15 小时前
git的安装以及基本命令使用、远程仓库的操作、vscode连接远程仓库进行项目的上传、gitee的使用
linux·git·gitee
kyriewen1 天前
Git Commit 前自动修复代码风格?配置 Husky + lint-staged,从此 CR 只聊逻辑
前端·git·面试
吹牛不交税1 天前
visualstudio把项目绑定git仓库
git
c238561 天前
git常见错误和ssh验证推送
运维·git·ssh
火山上的企鹅1 天前
Codex实战:APP远程升级服务搭建(四)Node 服务端自动识别 APK 信息
android·服务器·git·github·qgc