你知道git rebase 和 git merge的区别吗?

它们是什么

在使用git进行版本管理的项目中,当完成一个功能的开发并将其合并到master分支时,会有两种方式:

  • git merge
  • git rebase

git rebasegit merge都有相同的作用,都是将一个分支的提交合并到另一分支上,但是在原理上却不相同。

用法上两者也十分的简单:

git merge

将当前分支合并到指定分支,命令用法如下:

js 复制代码
git merge xxx

git rebase

将当前分支移植到指定分支或指定commit之上,用法如下:

js 复制代码
git rebase -i <commit>

常见的参数有--continue,用于解决冲突之后,继续执行rebase

js 复制代码
git rebase --continue

这两个的执行

git merge

通过git merge将当前分支与xxx分支合并,产生的新的commit对象有两个父节点,如果"指定分支"本身是当前分支的一个直接子节点,则会产生快照合并。

举个例子,bugfix分支是从master分支分叉出来的,如下所示:

合并bugfix分支到master分支时,如果master分支的状态没有被更改过,即 bugfix分支的历史记录包含master分支所有的历史记录,所以通过把master分支的位置移动到bugfix的最新分支上,就完成合并。

如果master分支的历史记录在创建bugfix分支后又有新的提交,如下情况:

这时候使用git merge的时候,会生成一个新的提交 ,并且master分支的HEAD会移动到新的分支上,如下:

从上面可以看到,会把两个分支的最新快照以及二者最近的共同祖先进行三方合并,合并的结果是生成一个新的快照。

git rebase

同样,master分支的历史记录在创建bugfix分支后又有新的提交,如下情况:

通过git rebase,会变成如下情况:

在移交过程中,如果发生冲突,需要修改各自的冲突,如下:

rebase之后,masterHEAD位置不变。因此,要合并master分支和bugfix分支:

从上面可以看到,rebase会找到不同的分支的最近共同祖先,如上图的B,然后对比当前分支相对于该祖先的历次提交,提取相应的修改并存为临时文件 (老的提交XY也没有被销毁,只是简单地不能再被访问或者使用) ,然后将当前分支指向目标最新位置D, 然后将之前另存为临时文件的修改依序应用。

区别

从上面可以看到,mergerebasea都是合并历史记录,但是各自特性不同:

  1. 工作原理

    • git merge:将一个分支的更改合并到另一个分支。它会创建一个新的提交,该提交将两个分支的更改合并在一起,并且保留了每个分支上的历史记录。
    • git rebase:将当前分支的提交"移动"到目标分支的顶部,而不是创建一个新的合并提交。它会将当前分支的更改应用到目标分支的提交上,然后将当前分支移动到目标分支的最新提交之后。
  2. 提交历史

    • git merge:保留了每个分支的提交历史,并创建了一个新的合并提交,其中包含了两个分支的更改。
    • git rebase:将当前分支的提交"重播"在目标分支的提交之上,因此它会产生一个更线性的提交历史,看起来更加清晰。这种方法有助于保持项目历史的整洁性,但可能会导致变基后的提交 ID 发生变化,这可能会影响到已共享的提交。
  3. 合并冲突处理

    • git merge:在合并过程中,如果存在冲突,Git 会创建一个合并提交,并提示用户手动解决冲突。解决完冲突后,再提交合并结果。
    • git rebase:在重新应用每个提交的过程中,如果存在冲突,Git 会在每个冲突点停止,让用户解决冲突。然后用户可以使用 git rebase --continue 命令继续重新应用提交,直到全部提交都被应用完毕。
  4. 使用场景

    • git merge:适用于合并相对较稳定的分支,如主分支或者长期存在的开发分支。它将保留每个分支的完整历史记录,并创建一个新的合并提交,记录合并时的状态。
    • git rebase:通常用于将开发分支与目标分支同步,以便于保持一个清晰、线性的提交历史。这有助于避免分支合并后产生大量的合并提交,使得提交历史更易于理解和管理。
相关推荐
蓝婷儿17 分钟前
每天一个前端小知识 Day 27 - WebGL / WebGPU 数据可视化引擎设计与实践
前端·信息可视化·webgl
然我24 分钟前
面试官:如何判断元素是否出现过?我:三种哈希方法任你选
前端·javascript·算法
OpenTiny社区44 分钟前
告别代码焦虑,单元测试让你代码自信力一路飙升!
前端·github
pe7er1 小时前
HTTPS:本地开发绕不开的设置指南
前端
晨枫阳1 小时前
前端VUE项目-day1
前端·javascript·vue.js
江山如画,佳人北望1 小时前
SLAM 前端
前端
患得患失9491 小时前
【前端】【Iconify图标库】【vben3】createIconifyIcon 实现图标组件的自动封装
前端
颜酱1 小时前
抽离ant-design后台的公共查询设置
前端·javascript·ant design
用户95251151401551 小时前
js最简单的解密分析
前端
FogLetter1 小时前
深入浅出React-Router-Dom:从前端路由到SPA架构的华丽转身
前端·react.js