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 <目录> <分支> 会把两者绑定起来。

相关推荐
憧憬成为java架构高手的小白9 小时前
git多人工作之个人规范使用【ai+个人理解】
git
CVer儿9 小时前
git简单操作
git
Andya_net10 小时前
Git | Git 核心命令深入解析:从原理到实战
大数据·git·elasticsearch
wh_xia_jun10 小时前
给小白的 Maven 命令行执行测试 完整指南
git·maven·intellij-idea
专业白嫖怪11 小时前
H3C UniServer R4950 G5 服务器压测实战:13根内存条24小时压力测试全流程
git
我先去打把游戏先11 小时前
Ubuntu虚拟机(服务器版本)Git安装教程(附常用命令)——从零开始掌握版本控制
服务器·c语言·c++·git·嵌入式硬件·物联网·ubuntu
咸鱼永不翻身11 小时前
Git Hooks 功能与作用详解
git·git-hooks·git钩子
闪电悠米11 小时前
黑马点评短信登录01_session_sms_login
java·spring boot·redis·git·spring·面试
少司府11 小时前
Tools相关:深入浅出学Git
大数据·c++·git·gitee·github·仓库·分支