git worktree实现分支管理

文章目录

简介

简单来说,git worktree(工作树)是 Git 提供的一个非常强大的高级功能。允许在同一个本地 Git 仓库下,同时检出(checkout)并运行多个不同的分支,并且每个分支都拥有自己独立的物理文件夹。

为什么需要它

想象一下正在开发一个需求:

正在 feature-A 分支上疯狂敲代码,改了十几个文件,项目正跑在本地服务器上。

突然,测试跑过来说:线上出了个紧急 Bug,需要马上切到 main 分支去修复。

传统的做法非常痛苦:

必须先打断当前的思路,把改了一半的代码 git stash 暂存起来(或者写个临时的 commit),然后再 git checkout main。这往往会导致 IDE(比如 IDEA 重新建立索引)、本地服务器报错、热更新失效,搞定之后切回来还得重新恢复现场。

git worktree 的做法极其优雅:

完全不需要动当前正在开发的文件夹。可以直接用 git worktree 命令,在旁边新建一个文件夹,并且这个新文件夹直接绑定 main 分支。

可以用另一个 IDE 窗口打开这个新文件夹去修 Bug。修完后,正在开发的 feature-A 现场依然完好无损。

如何实现

1. 命令式

  • 新建一个工作树并关联分支
bash 复制代码
# 在当前目录的上一层(../)创建一个名为 hotfix-dir 的文件夹
# 并在这个文件夹里检出 main 分支
git worktree add ../hotfix-dir main

# 如果想基于当前分支新建一个名为 bugfix 的分支,并放到新目录中:
git worktree add -b bugfix ../bugfix-dir
  • 查看当前有哪些工作树
bash 复制代码
git worktree list
  • 用完之后删除它
bash 复制代码
# 安全移除工作树(Git 会检查是否有未提交的代码)
git worktree remove ../hotfix-dir

# 如果里面有不想保留的修改,直接强制干掉:
git worktree remove -f ../hotfix-dir

2. 插件式

以idea为例:

  • File->setting->plugins,查询并安装Git Worktree
  • 点击左侧的Git,右击选择Add Worktree
  • 新建一个空的文件夹,下拉框选择基于哪个分支,这里示例的main分支
  • 弹窗一个全新的 IDEA 窗口,直接改代码就行!旧窗口的一切原封不动。
  • 完成开发后,删除

总结

对于经常需要在多个分支之间反复横跳、或者同时处理多个并行任务的开发者来说,git worktree 是一个能大幅提升体验的"神级命令"。

以上为个人学习分享,如有问题,欢迎指出:)

相关推荐
AIMath~5 小时前
如何将一个新的文件夹使用git 工具提交到github新仓库中
git·github
满天星83035775 小时前
【Git】原理及使用(二) (版本回退)
linux·git
愿天垂怜6 小时前
【C++脚手架】ffmpeg 库的介绍与使用
linux·服务器·开发语言·c++·ide·git·ffmpeg
月夜的风吹雨6 小时前
Linux 基础开发工具详解:从 yum 到 gdb 实战指南
linux·git·ubuntu·centos·vim
好运yoo6 小时前
git cherry-pick
git
不是光头 强7 小时前
Obsidian Git 插件安装与配置完全指南
git
.千余7 小时前
【C++】C++核心语法:函数重载与缺省参数原理与避坑
c语言·开发语言·c++·经验分享·笔记·git·学习
meowrain8 小时前
Git HTTPS Token 凭据配置指南
git·网络协议·https
Ws_19 小时前
Git + Gerrit 第二课:diff、暂存区与撤销修改
git
snowjlz20 小时前
鸿蒙版SVN来了!!!
git·svn·版本控制