Git Worktree

Git Worktree 是什么?

git worktree 是 Git 自带的多分支并行工作 工具,它能让你在同一个 Git 仓库下,同时检出多个不同分支,并且每个分支都有独立的工作目录(文件夹)。

简单说:不用频繁切换分支、不用克隆多个仓库,就能同时开发/调试多个分支


一、解决什么痛点?

平时用 Git 切换分支时,会遇到这些麻烦:

  1. 开发到一半,要紧急改另一个分支的 bug,必须先 commit/stash 暂存代码,很繁琐;
  2. 切换分支后,工作目录文件会被覆盖,容易误改、误删;
  3. 想同时对比两个分支的代码、运行两个版本的项目,只能重复克隆仓库,浪费空间。

git worktree 完美解决这些问题。


二、核心特点

  1. 共享同一个 .git 仓库:所有工作目录共用仓库的提交历史,不重复占用磁盘空间;
  2. 独立工作目录:每个分支一个文件夹,互不干扰;
  3. 无需频繁切换分支:直接打开对应文件夹就能开发;
  4. 原生 Git 命令:不用装插件,Git 2.5+ 版本自带。

三、常用命令(直接复制用)

1. 查看当前所有工作树

bash 复制代码
git worktree list

会显示:主目录 + 所有附加的工作树、对应分支、路径。

2. 创建新的工作树(指定分支)

bash 复制代码
# 格式:git worktree add <文件夹名> <分支名>
git worktree add bug-fix fix-branch-123

执行后:

  • 会生成 bug-fix/ 文件夹;
  • 自动检出 fix-branch-123 分支;
  • 直接进入这个文件夹就能开发,和主目录完全隔离。

3. 删除不需要的工作树

bash 复制代码
# 先删除文件夹,再清理 Git 记录
rm -rf bug-fix
git worktree prune

4. 快速创建新分支 + 新工作树

bash 复制代码
git worktree add new-feature -b new-branch-name

四、使用场景(最实用)

  1. 紧急修复 bug :主分支开发到一半,直接开一个 worktree 切到修复分支,改完提交,回到主分支继续写代码,不用 stash、不用切换
  2. 同时开发多个功能:一个目录写功能 A,一个目录写功能 B,互不干扰;
  3. 对比/测试两个版本:同时运行生产分支、开发分支,方便调试差异;
  4. ** reviewing 代码**:给同事的分支建一个独立目录,直接查看、运行代码。

五、和普通切换分支、多克隆仓库的区别

方式 优点 缺点
git checkout 切换分支 简单,适合临时切换 干扰当前工作,容易出错
克隆多个仓库 完全隔离 占用双倍空间,同步提交麻烦
git worktree 隔离、共享仓库、不占空间、高效 需记住命令(很简单)

总结

  1. git worktree = 同一个 Git 仓库,多个独立分支工作目录
  2. 核心价值:不切换分支、不重复克隆,同时并行处理多个分支
  3. 高频命令:add(创建)、list(查看)、prune(清理)。
相关推荐
A_Lonely_Cat2 天前
记一次 GitHub 幽灵协作者大清洗:强制重写 Git 历史与穿透 CDN 缓存实践
git·github
和你看星星4 天前
Git rerere:让重复冲突只解决一次
git
嘻嘻仙人8 天前
Ubuntu中 git上传自己的项目和二次上传一般流程
git·github
Patrick_Wilson8 天前
Squash Merge 的血缘陷阱:为什么删掉的代码又活了过来
前端·git·程序员
沉浸学习的匿名网友8 天前
什么是 .gitignore?为什么每个 Git 项目几乎都离不开它?
前端·git
深海鱼在掘金9 天前
Git 完全指南 —— 第3章:理解工作区、暂存区、版本库三个核心
git
江华森9 天前
Git 基础筑基:从原理到团队协作的全栈实战
git
JakeJiang9 天前
Git 必备命令指南:从日常高频到项目开发实战
git
叫我少年10 天前
Windows 中安装 git
git
深海鱼在掘金15 天前
Git 完全指南 —— 第1章:Git 概览与版本控制演进
git