Git:图解 merge 和 rebase 的区别

在 Git 的交汇处,每一次选择都是代码旅程的新起点。

在 Git 中,Merge 和 Rebase 是两种常用的分支整合方式,但是一些初学的小伙伴可能不知道它们之间有什么区别,以及二者该怎么选择。

本文将深入探讨 Merge 和 Rebase 的区别,帮助你更好地理解和运用它们,以提高代码管理的效率和质量。

Merge | 分支交汇的交叉路口

Merge的原理很简单,就是将要合并的两个分支的最新提交组合成一个新的提交,并且插入到目标分支中。

假设现在有一个 main 分支和一个 feature 分支,如图(图中数字为提交的先后次序,即最早的提交是1,然后是2,其次是3):

现在我想要把分 feature 分支 merge 到 main 分支上去,那么 git 会把两个分支的最新提交4和5合并成一个提交,并且合入目标分支 main:

当然,如果4和5中存在代码冲突,必须先解决代码冲突才能合并。

最终会得到这么两个分支:

具体的 merge 操作为:

git 复制代码
git checkout main
git merge feature

Rebase | 提交历史的线性编织

与 merge 不同的是,rebase 并不会保留原有的提交,而是会创建当前分支比目标分支更新的所有提交的副本, 在上述例子中(将 feature 变基到 main)就是 2' 和 4',然后将 2' 和 4' 按次序插入目标分支末尾:

这样就完成了一个 rebase 的过程。

同样,如果有代码冲突,首先需要解决冲突才能 rebase 成功。

最终得到的两个分支为:

具体的 rebase 操作为:

git 复制代码
git checkout main
git rebase feature

适用场景

不难发现,merge 和 rebase 最大的区别在于是否会保留原有的提交(或者说破坏原有的提交结构)。

merge 会对提交历史进行保留,很显然更适合多人协作开发的场景,因为如果出现问题也可以追溯到历史的每一次提交。

而 rebase 则是会让提交历史更加简洁易读,保持提交历史的线性结构,所以更适合个人开发和整理分支的情况。

一句话概括就是,如果我想要把某个特性分支 feature_xxx 合并到 main 分支中的时候,最好的方式就是 merge,而当我一个人需要开发某个 feature_xxx 分支的时候,最好的方式就是 rebase。

相关推荐
可乐加.糖7 分钟前
项目版本管理和Git分支管理方案
java·git·目标跟踪·gitlab·敏捷流程·源代码管理
wingaso17 分钟前
[经验总结]删除gitlab仓库分支报错:错误:无法推送一些引用到“http:”
linux·数据仓库·git
qianmoQ6 小时前
GitHub 趋势日报 (2025年05月14日)
github
ice___Cpu9 小时前
Git - 1( 14000 字详解 )
大数据·git·elasticsearch
Yvonne爱编码9 小时前
CSS- 2.1 实战之图文混排、表格、表单
前端·css·html·github·状态模式·html5·hbuilder
qianmoQ19 小时前
GitHub 趋势日报 (2025年05月11日)
github
Yvonne爱编码20 小时前
HTML-3.3 表格布局(学校官网简易布局实例)
前端·html·github·html5·hbuilder
范纹杉想快点毕业1 天前
以项目的方式学QT开发(一)——超详细讲解(120000多字详细讲解,涵盖qt大量知识)逐步更新!
c语言·数据结构·c++·git·qt·链表·github
qq_653644461 天前
如何查看打开的 git bash 窗口是否是管理员权限打开
开发语言·windows·git·bash
tonngw1 天前
【Mac 从 0 到 1 保姆级配置教程 12】- 安装配置万能的编辑器 VSCode 以及常用插件
git·vscode·后端·macos·开源·编辑器·github