好用!Git 同时开发多个分支

要在同一台电脑上对同一个 Git 项目同时开发多个分支,最推荐、最高效的方法是使用 git worktree

这就好比你给同一个 Git 仓库(Repository)配了多把"钥匙"(工作树),每一把钥匙打开一个独立的文件夹,每个文件夹里是同一个项目的不同分支。这样你就可以在 VS Code 或 PyCharm 中同时打开这几个文件夹,互不干扰。

以下是具体的操作步骤和对比分析:

🚀 核心方案:使用 git worktree (强烈推荐)

这是 Git 官方提供的功能,不需要复制庞大的 .git 文件夹,非常轻量。

1. 创建新的工作树(分支文件夹)

假设你当前在项目根目录下(例如 ProjectA),想要在上级目录中创建一个专门用于修复 Bug 的分支:

复制代码
# 命令格式:git worktree add <新文件夹路径> <分支名>
git worktree add ../ProjectA_hotfix fix-branch-name
  • 如果分支不存在 :你可以在命令末尾加上 -b 参数来创建新分支。

    复制代码
    git worktree add -b ../ProjectA_feature feature/login origin/main

    注:这表示基于远程的 main 分支,创建一个本地的 feature/login 分支,并放在 ../ProjectA_feature 文件夹中。

2. 打开并开发

创建成功后,你会在上级目录看到一个新的文件夹 ProjectA_hotfix

  • 直接用你的 IDE(如 VS Code、IntelliJ IDEA)打开这个新文件夹。
  • 此时这个文件夹独立运行,你可以安装依赖、启动服务、修改代码,完全不会影响原本的 ProjectA 文件夹。
3. 删除工作树(任务完成)

当 Bug 修复完并提交代码后,你可以删除这个临时文件夹:

复制代码
# 在原项目根目录或任意 worktree 中执行
git worktree remove ../ProjectA_hotfix
  • 如果文件夹内有未提交的代码,Git 会阻止删除。强制删除请加 -f 参数:git worktree remove -f ../ProjectA_hotfix

🆚 方案对比:为什么选 git worktree

为了让你更直观地理解,我为你整理了三种常见方案的对比:

方案 操作方式 优点 缺点 推荐指数
Git Worktree git worktree add 共享 .git,磁盘占用小;完全隔离,可同时启动服务 管理不当可能产生"孤儿"记录 ⭐⭐⭐⭐⭐
手动克隆 git clone 项目两次 环境绝对隔离,操作简单 磁盘占用翻倍(每个都有 .git);配置繁琐 ⭐⭐
分支切换 git checkout / git stash 不占用额外空间 无法同时运行;切换耗时;易丢代码

💡 进阶管理命令

在使用过程中,你可能需要查看或清理状态,以下是常用的辅助命令:

  1. 查看所有工作树列表

    在任意一个该项目的工作树目录下执行:

    复制代码
    git worktree list

    它会列出所有关联的文件夹及其对应的分支。

  2. 清理无效记录

    如果你直接用文件管理器删除了文件夹(没有用 git worktree remove),Git 内部可能还会残留记录。这时可以用:

    复制代码
    git worktree prune

    这会清理掉那些已经不存在的文件夹的元数据。

📌 总结建议

如果你使用的是 VS CodeIntelliJ IDEA ,配合 git worktree 是最完美的组合。

  • 场景 :正在开发新功能(dev分支),突然要修线上 Bug(hotfix分支)。
  • 做法 :创建一个 worktree 指向 hotfix 分支,用新窗口打开,修完即删。
  • 体验 :就像同时拥有两个独立的项目,但实际上只占用一份 .git 的空间,且代码提交互不干扰。
相关推荐
stevenzqzq5 小时前
git 常用操作
大数据·git
Curvatureflight6 小时前
Git工作流最佳实践:从混乱到优雅
git
wu~9707 小时前
GitHub永不遗忘,使用git push -f来覆盖的提交依旧保留
git·github
Vermouth_009 小时前
git clone的时候提示access denied
git
qq_4376572710 小时前
清楚本地的git并重新登录
git
jiang_changsheng10 小时前
工作流agent汇总分析 2
java·人工智能·git·python·机器学习·github·语音识别
顶点多余11 小时前
版本控制器-git
linux·git
夔曦11 小时前
Git工程日常下拉/上传完整流程(自用)
git
岱宗夫up11 小时前
GitHub Desktop如何设置中文?这不是个简单问题
git·github
岱宗夫up14 小时前
.env 文件是干啥的?为什么不能提交到 Git?
大数据·git·elasticsearch·搜索引擎·gitee·github·gitcode