百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

开发中合并代码如何选择 git merge 还是 git rebase ?

bigegpt 2024-10-06 02:41 7 浏览

 git rebase git merge 是我们日常开发中使用的两种分支合并策略两者所处理的问题是相同的,它们都能够将分支代码合并到主分支,就是将一个分支上的改动集成到另一个分支上,区别在于他们实现的方式不同。
考虑如下的工作场景:

你要在当前项目开发一个新的功能点,于是基于dev分支拉出了一个feat-a分支开始进行开发。而与此同时你的同事基于dev在在fixbug-1分支上修复了一个bug。现在需要合并feat-a 和 fixbug-1分支到dev分支。


这里先假设你的同事先行把已在fixbug-1分支修复完成的bug合并到dev分支上

# 切换到 dev分支上
git checkout dev

# 合并 fixbug-1 到dev分支
git merge fixbug-1

基于上面的预设场景,你已经在feat-a分支完成了功能开发接下来我们分别使用 git mergegit rebase 来合并代码,具体看下会发生什么。


首先使用 git merge 进行合并

# 先拉取 remote 最新版本
git pull 

# 切换到dev分支
git checkout dev

# 合并自己开发的功能分支
git merge feat-a


从上面的图中可以看到 feat-a分支合并到dev分支过程中,历史提交线中自动新增了一个提交(c6)称呼为合并提交

使用 git rebase 进行合并

git rebase 仅从字面上来看:「rebase」「re」加上「base」,翻译成中文大概是重新定义分支的参考基准的意思,一般我们简称为变基。

# 先拉取 remote 最新版本
git pull 

# 切换到自己开发完成的功能分支feat-1上
git checkout feat-a

# 合并到dev
git rebase dev

从上面图中可以看到,执行 git rebase dev 命令后将原先在feat-a 分支上提交的 c2、c3两个提交记录复制到dev分支中(c2' 、c3'),并不会出现使用 git merge 合并时在历史提交现上产生多余的合并提交记录

上面我们分别使用了 git merge git rebase对分支进行合并,可以看到两者都实现了代码合并的目标,仅从目标结果来看两者是一致的,既然两者实际效果一样,那么实际工作中应该怎样选择使用呢?

git merge 和 git rebase 的选择

在怎样选择使用 git merge git rebase 时,先了解下两者的优缺点


git merge

优点:

  • git merge 合并操作比较直观
  • git merge 会保留所有的分支历史和合并点
  • 由于 git merge 不会改变现有的历史,它被认为是一种安全的操作

缺点:

  • 频繁的合并会在项目历史中创建很多的合并提交,从而使历史变得复杂难以跟踪。

git rebase

优点:

  • git rebase 使得历史记录看起来像是一条直线,没有分叉,从而便于理解项目的历史进展。
  • 由于重写了提交历史,git rebase 通常可以减少分支和合并提交的数量。
  • git rebase 可以避免在合并特性分支时产生额外的合并提交,避免不必要的合并提交。

缺点:

  • git rebase 实质上是改写历史,如果对已经公开的分支使用,可能会引起混乱和问题

从上面可以看到,git merge 侧重完整、安全而 git rebase 侧重整洁, 了解到两者的优缺点后,我们期望项目的提交记录既要完整、安全、又要整洁。为此我们可以采用下面的 策略方法:

在个人的 feature 分支上工作时,定期使用 git rebase main git rebase develop(取决于你的基础分支)可以保持你的分支更新,并避免将来与基础分支合并时出现大量的合并冲突。

feature 分支开发完成并准备并入主分支(如 main develop)时,通常会使用 git merge。这样可以保留一个清晰的结构,说明何时以及为何将特定的功能并入主分支。

小结一下

git merge git rebase 两者都可以用来合并分支, git merge 保留了真实的、时间线性的项目历史,清晰地表示了何时以及为何会并合并一个分支,并且它不会改变历史。git rebase 创建了一条线性的历史,让历史看起来更干净整洁。避免了不必要的合并提交。在某些情况下能更清晰的显示提交的顺序。可能会改变历史,因为它实际上是创建了新的提交。

通常建议在个人的本地分支上使用 git rebase 保持历史干净,在公共分支(像是主分支或发布分支)上使用 git merge 保持历史的真实性。

另外需要紧记:切记不要对已经推送到远程仓库的分支执行 rebase 操作,因为它会改变已经公布的历史,这会给其他开发者带来麻烦。

最后建议在工作中遵守这样的法则:公共分支使用 git merge 合并,本地分支使用 git rebase合并。

相关推荐

5分钟调色大片的方法(5分钟调色大片的方法有哪些)

哈喽大家好。在大家印象中一定觉得ps非常难学非常难。大家不要着急,小编的教学都是针对ps零基础的同学的,而且非常实用哦。只要大家跟着图文练习一两遍,保证大家立马学会~!好了,废话少说,下面开始我们今天...

闪白特效原来是这么用的(闪白特效怎么使用)

作者|高艳侠订阅|010-86092062闪白特效是影视作品中应用比较多的效果之一,那么具体该在哪些场景使用闪白特效?具体该如何操作?下面就以AdobePremiere(以下简称PR)为例,...

ppt常用小图标去哪里找?3个矢量素材网站推荐!

ppt是一个注重可视化表达的演示载体,除了高清图片,ppt中另一类常用的素材是各种小图标,也叫矢量图标,巧妙运用小图标能提升整体美观度和表现力,那么ppt常用小图标去哪里找呢?为方便各位快速找到合适的...

有什么好用的截图录屏工具?试试这9款

经常有朋友反馈苦于缺乏截屏和录屏的趁手工具,本期我们分享几个相当好用的截屏和录屏工具,希望能帮到大家。ScreenToGifScreenToGif是一款免费且开源的录屏工具。此款工具最大的特点是可以...

配色苦手福音!专业快速色环配色PS插件

今天橘子老师给的大家介绍的是一款快速配色的插件,非常强大配色苦手福音来啦!(获取方式见文末)【插件介绍】配色在后期设计中占有主导地位,好的配色能让作品更加抢眼Coolorus这款专业的配色插件,能够...

如何用PS抠主体?(ps怎么抠主体)

1.主体法抠图-抠花苞和花梗导入一张荷花苞的照片,点击上图中顶部“选择”菜单栏,下拉单击“主体”。可以看到,只有花苞被选中,但是花梗并没有被选中。接下来单击上图中左侧工具栏的“快速选择工具”,上图中顶...

2799元的4K电视,有保障吗?(买4k电视机哪个品牌好)

在上一期《电脑报》的3·15专题报道中,我们揭露了一款不靠谱的42英寸4K智能电视——TCLD42A561U。这款售价2699元的4K智能电视不仅4K画质方面存在严重问题,而且各种功能和应用体验也不理...

苹果电脑的Touch Bar推出一段时间了 这款工具可以帮你开发适用于它的APP

距离苹果推出带有TouchBar的MacBookPro已经有一段时间了,除了那些像Adobe、Google和Microsoft大公司在开发适用于TouchBar的应用之外,其实还有很多独立的开...

如魔法般吸取颜色的桌灯(如魔法般吸取颜色的桌灯叫什么)

色彩为生活带来的感官刺激,逐渐被视为理所当然。一盏桌灯运用它的神奇力量,将隐藏于物件中的颜色逐一释放,成为装点环境的空间魔法师。ColorUp是一款可以改变颜色的吸色台灯,沿用传统灯泡的造型,融入了拾...

一篇文章带你用jquery mobile设计颜色拾取器

【一、项目背景】现实生活中,我们经常会遇到配色的问题,这个时候去百度一下RGB表。而RGB表只提供相对于的颜色的RGB值而没有可以验证的模块。我们可以通过jquerymobile去设计颜色的拾取器...

ps拾色器快捷键是什么?(ps2019拾色器快捷键)

ps拾色器快捷键是什么?文章末尾有获取方式,按照以下步骤就能自动获得!学会制作PS特效需要一定程度的耐心和毅力。初学者可以从基本的工具和技术开始学习,逐渐提高他们的技能水平。同时,观看更多优秀的特效作...

免费开源的 Windows 截图录屏工具,支持 OCR 识别和滚动截图等

功能很强大、安装很小巧的免费截图、录屏工具,提供很多使用的工具来帮我么能解决问题,推荐给大家。关于ShareXShareX是一款免费的windows工具,起初是一个小巧的截图工具,经过多年的迭...

入门到精通系列PS教程:第13篇 · 拾色器、颜色问题说明及补充

入门到精通系列PS教程:第13篇·拾色器、颜色问题说明及补充作者|侯潇问题说明我的第12篇教程里,有个小问题没有说清楚。要说是错误,又不算是错误,只是没有说准确。写完那篇教程后,因为已经到了深...

PS冷知识:用吸管工具吸取屏幕上的任意颜色

今天,我们给大家介绍PS中的一个冷知识:用吸管工具可以吸取屏幕上的任意颜色。其实,操作起来是非常简单的。大多数情况下,我们认为,PS的吸管工具只能吸取PS软件作图区域范围内的颜色,最多加上画布四周的...

Windows 11 将提供内置颜色选择器工具

Windows11内置了颜色选择器,可以扫描并识别屏幕上的颜色并生成颜色代码。此外,微软还利用人工智能技术,让屏幕上的文本扫描和选择变得更加便捷。这两项功能均已在SnippingToolv1...