rebase 与 merge

🧩 一、核心区别:操作对象不同

操作 直译含义 dev 的基点变化 commit 历史是否重写 是否产生 merge commit
git rebase dev onto test "把 dev 移动到 test 上" ✅ 会改变(dev 的提交会重新基于 test) ✅ 会重写(新 commit ID) ❌ 不产生(线性历史)
git merge test into dev "把 test 合并进 dev" ❌ 不变(dev 保持原来的基点) ❌ 不重写 ✅ 会产生一个 merge commit

🧭 二、过程可视化理解

假设当前分支结构如下:

scss 复制代码
A---B---C (test)
         \
          D---E (dev)

✅ 执行 git rebase dev onto test 后:

dev 的提交 D、E 会 复制一份并重新接到 test 的 C 后面

css 复制代码
A---B---C---D'---E' (dev)

📌 效果:

  • 看起来像 dev 是直接从 test 派生的;
  • 历史是干净、线性的;
  • 但 D/E 的 commit hash 都变了(因为 rebase 本质是"复制+删除原提交")。

✅ 执行 git merge test into dev 后:

dev 会把 test 的提交合并进来,并生成一个合并提交:

scss 复制代码
A---B---C (test)
         \ 
          D---E---M (dev)

📌 效果:

  • dev 得到了 test 的所有改动;
  • 历史保留了两个分支的分叉;
  • 生成一个新的 merge commit M
  • 所有原 commit hash 保持不变。

⚖️ 三、使用场景对比

场景 推荐操作 原因
你在自己的分支上开发,还没推到远程,只想同步 test 最新改动 rebase dev onto test 保持线性历史,方便 review
dev 已经是共享分支,有多人在上面工作 merge test into dev 避免改写公共历史,安全
准备发 PR(希望提交历史干净) rebase 去掉不必要的 merge commit
要完整保留开发过程、分支结构 merge 历史清晰,易于追踪分支来源

💡 四、总结一句话

  • rebase:像是"重新整理笔记",让历史更整齐。
  • merge:像是"把两本书合成一本",保留所有分叉记录。
相关推荐
小王C语言11 小时前
版本控制器git和调试器gdb
git
-大头.12 小时前
GIT教程系列(共3篇)---------第一篇:Git入门与核心概念完全指南
大数据·git·elasticsearch
_Xiaosz15 小时前
Git 拉取子模块报错 Permission denied (publickey) 的排查与解决
git
晚霞的不甘15 小时前
Flutter for OpenHarmony 实战:[开发环境搭建与项目编译指南]
git·flutter·react native·react.js·elasticsearch·visual studio code
-大头.16 小时前
GIT教程系列(共3篇)-----第三篇:Git高级技巧与专业配置完全指南
大数据·git·elasticsearch
查拉图斯特拉面条16 小时前
Git推送完全指南:从首次推送到冲突解决
大数据·git·elasticsearch
脸大是真的好~16 小时前
Git的快速使用
git
沛沛老爹16 小时前
从Web到AI:金融/医疗/教育行业专属Skills生态系统设计实战
java·前端·人工智能·git·金融·架构
夜流冰16 小时前
Git - 学习掌握Git的建议
git·学习
小鸡脚来咯1 天前
Git 新手入门指南
大数据·git·elasticsearch