一图看懂git merge和git rebase的区别!!

一图看懂git merge和git rebase的区别!!

Git 是一个非常流行的版本控制系统,它帮助开发者管理代码的不同版本。在 Git 中,mergerebase 是两种常用的将不同分支的更改合并到一起的方法,但它们在处理方式和结果上有所不同。

Git Merge(合并)

  1. 定义git merge 是将两个或多个开发历史记录合并在一起的操作。
  2. 过程:当你执行 git merge 命令时,Git 会在两个分支之间创建一个新的“合并提交”(merge commit),这个提交会同时指向两个分支的历史点。
  3. 优点
    • 保留了完整的历史记录,可以清晰地看到分支的合并点。
    • 合并操作是不可逆的,不会改变项目的历史。
  4. 缺点
    • 可能会产生多余的合并提交,使得历史记录变得复杂。
    • 合并冲突可能更难以解决,因为它们被合并到了一个单独的提交中。

Git Rebase(变基)

  1. 定义git rebase 是将一系列提交从一个分支上摘下来,然后再应用到另一个分支上的操作。
  2. 过程:执行 git rebase 时,Git 会将当前分支上的提交暂存起来,然后将当前分支指向目标分支的顶部,之后将暂存的提交依次应用。
  3. 优点
    • 可以创建一个更干净、线性的提交历史。
    • 减少了合并提交的数量,使得历史记录更加清晰。
  4. 缺点
    • 变基会改变历史记录,如果不正确使用,可能会导致问题。
    • 变基操作是可逆的,但如果在变基后与其他人共享了分支,可能会引起混乱。

一图总结

A---B---C---D  Topic1 (初始状态)
      \
        E---F---G  Topic2 (初始状态)

使用 git merge Topic2
A---B---C---D---H  Topic1 (合并后的Topic1)
     \            (H 是合并提交)
      E---F---G  Topic2

使用 git rebase Topic2 到 Topic1
A---B---C---D---E'---F'---G'  Topic1 (变基后的Topic1)
                          /
                         E---F---G  Topic2 (E', F', G' 是重新应用的提交)

在上图中,Topic1Topic2 是两个分支,ADTopic1 的提交,EGTopic2 的提交。使用 git merge 会创建一个新的合并提交 H,而使用 git rebase 会将 EFG 重新应用到 D 的顶部,生成 E'F'G'

选择使用 merge 还是 rebase 通常取决于团队的工作流程和个人偏好。在公共分支上,通常推荐使用 merge 以保持历史的完整性,而在特性分支或个人分支上,使用 rebase 可以保持历史的清洁和线性。

综上总结

在这里插入图片描述

  • git merge和git rebase都具有合并分支的功能,
    但两者又有不同:
    rebase: 变基: 把一个分支的更改移动到另一个分支上,通常用于保持提交历史的线性和干净
    merge: 合并: 把一个分支的更改合并到另一个分支,合并后的提交会保留原始分支的提交历史
    rebase: 解决完冲突后不会产生额外的commit
    merge: 解决完冲突后会产生一个commit
    图中非常形象的展示了二者的不同,

  • 所以rebase是把main的commit记录给删掉了吗?

    • 回答:不是,变基是以目标分支的commit为基础合并,从而忽略main分支的提交记录。

仁者见仁,智者见智,个人推荐使用merge

  • git rebase 只适合在自己的branch用,不然一直会产生branch垃圾(可以删除解决)
  • 而且如果是团队开发,rebase对团队成员能力要求较高
  • rebase需要提交要遵守黄金法则,要慎重
  • 黄金法则; Never use rebase on public branches,永远不能在一个共享的分支上进行Git rebase操作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/620242.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

一篇教你python网页自动化

一篇教你python网页自动化 网页自动化 一篇教你python网页自动化[TOC](网页自动化) 前言一、安装Python?二、安装Selenium库:1.下载WebDriver:2.第二部分:基本网页操作 三、元素定位与操作:图文演示获取选择器写的一个…

百面算法工程师 | 正则优化函数——BN、LN、Dropout

本文给大家带来的百面算法工程师是正则优化函数,文章内总结了常见的提问问题,旨在为广大学子模拟出更贴合实际的面试问答场景。在这篇文章中,我们将总结一些BN、LN、Dropout的相关知识,并提供参考的回答及其理论基础,以…

探秘原子写:为数据完整性再加一分!

对存储设备来说,确保数据的准确记录和读取是其核心使命。鉴于NAND Flash独特的工作原理,当数据需要更新时,SSD往往会将新的数据直接存储到空白的PBA物理块地址上,随后建立LBA逻辑块地址与PBA的映射关系,并将LBA原先指向…

2024中国(重庆)VR/AR科技展8月举办

2024中国(重庆)VR/AR科技展8月举办 邀请函 主办单位: 中国航空学会 重庆市南岸区人民政府 招商执行单位: 重庆港华展览有限公司 展会背景: 2024中国航空科普大会暨第八届全国青少年无人机大赛在重庆举办,同时举办第二届中国…

Jupyter配置

一、修改Jupyter打开界面 (1)打开【Anaconda Prompt】,输入【jupyter notebook --generate-config】命令 从运行结果可知【jupyter_notebook_config.py】的位置 (2)使用【记事本】打开 找到# c.NotebookApp.noteb…

【Qt】之【CMake】Error : The source.. does not match the soused

QT中cmak编译出现CMake Error: The source… does not match the soused 分析 前提是该项目是从另一个路径的项目复制过来的,编写代码时发现无论怎样修改代码,运行后都没有任何变化,以为是qtbug,重构重启都没用,最后…

【多电压流程 Multivoltage Flow】- 5.特定工具使用建议(5.使用ICC II以及FC进行物理实现)

使用IC Compiler II和Fusion Compiler进行物理实现 在完成带有行站点、电源规划和I/O放置的floorplan之后,可以继续进行物理综合和实现。Fusion Compiler提供了广泛的功能,以执行设计的平面物理实现。 图67显示了物理实现流程的一般步骤以及流程的低功耗支持特性。 图67 I…

PCL PolygonMesh数据结构

目录 一、函数源码二、主要函数三、读写数据四、代码案例五、结果展示六、相关链接本文由CSDN点云侠原创,原文链接。如果你不是在点云侠的博客中看到该文章,那么此处便是不要脸的GPT爬虫。 一、函数源码 #pragma once

Android Studio高版本安卓模拟器抓取https包

Android Studio avd 设置 证书生成 *.cer格式证书​ openssl x509 -inform DER -subject\_hash\_old -in charles-ssl-proxying-certificate.cer​ *.pem格式证书​ openssl x509 -inform PEM -subject\_hash\_old -in charles-ssl-proxying-certificate.pem会输出 2cb30a9e …

二叉树的四种遍历代码实现

二叉树的遍历大致能分为以下几种 1.前序:根 左 右 2.中序:左 根 右 3.后序:左 右 根 4.层序:从根开始一层一层的向下 如上图访问顺序: 前序:1 2 3 N N N 4 5 N N 6 N N 中序:N 3 N 2 N 1 N 5 N 4 N …

小成本大保障:中小企业的数据安全解决方案

在经营预算有限的情况下,中小企业面临着保障数据安全的巨大挑战。数据泄露不仅会导致财务损失,还会损害企业声誉,甚至可能违反数据保护法规。以下是一些成本效益高、实施简便的数据安全解决方案,帮助中小企业在小成本下实现大保障…

【爬虫】爬取股票历史K线数据写入数据库(三)

前几天有写过两篇: 【爬虫】爬取A股数据写入数据库(二) 【爬虫】爬取A股数据写入数据库(一) 现在继续完善,分析及爬取股票的历史K线数据通过ORM形式批量写入数据库。 2024/05,本文主要内容如下…

十五、Redis缓存常见问题

Redis作为最常用的缓存中间件,在使用过程中,必然会遇到过;**缓存穿透、缓存雪崩、缓存击穿。**这三个可以说是Redis缓存使用过程中,最常见的问题,且也是面试中最常闻到的问题。1、缓存穿透 **缓存穿透:**是…

【手势操作-复习前一天的内容-预习今天的内容 Objective-C语言】

一、昨天呢,我们学习的是这个,事件 1.事件这一块儿呢,iOS事件,分为三大类, 1)触摸事件 2)加速计事件 3)远程控制事件 2.这个里边呢,我们主要学习的是这个触摸事件,触摸事件里边,就是Touch,touchesBegan:方法里边,有一个touches参数,它是set类型的, 3.Set,…

启动项目时出现SELinux is preventing

问题描述 启动项目时出现SELinux is preventing**** SELinux正在阻止systemd对文件AB.sevice进行读取访问。 我的是启zabbix是报该错: 最终解决方案 方法一:暂时禁用SELinux setenforce 0 方法二:禁用SELinux 在配置文件/etc/sysconfig/…

韵搜坊(全栈)-- 前后端初始化

文章目录 前端初始化后端初始化 前端初始化 使用ant design of vue 组件库 官网快速上手:https://www.antdv.com/docs/vue/getting-started-cn 安装脚手架工具 进入cmd $ npm install -g vue/cli # OR $ yarn global add vue/cli创建一个项目 $ vue create ant…

【网络安全入门】你必须要有的学习工具(附安装包)零基础入门到进阶,看这一篇就够了!

工欲善其事必先利其器 在新入门网络安全的小伙伴而言。这些工具你必须要有所了解。本文我们简单说说这些网络安全工具吧! Web安全类 Web类工具主要是通过各种扫描工具,发现web站点存在的各种漏洞如sql注入、xss等。从而获取系统权限,常用的…

相同的树LeetCode

100. 相同的树 - 力扣(LeetCode100. 相同的树 - 力扣( 给你两棵二叉树的根节点 p 和 q ,编写一个函数来检验这两棵树是否相同。 如果两个树在结构上相同,并且节点具有相同的值,则认为它们是相同的。 /*** Definition…

css 步骤条虚线渐变色效果实现

效果如图所示&#xff1a; 思路&#xff1a; 使用元素覆盖的方式实现视觉上虚线的效果 实现代码&#xff1a; html布局 <ul class"details-cont"><li class"details-li" v-for"item in 3" :key"item"><div class&qu…

如何从未入库的gerrit中撤销一个文件

用一个例子说明 比如有一个提交里面的default.xml的修改没有必要&#xff0c;需要从未入库的gerrit中移除 步骤如下&#xff1a; 1.做reset操作 git reset HEAD^ packages/SettingsProvider/res/values/defaults.xml 2.做checkout操作 git checkout packages/SettingsProv…