Git 中 pull 操作和 rebase 操作的不同

2024-06-24 04:52
文章标签 操作 不同 git pull rebase

本文主要是介绍Git 中 pull 操作和 rebase 操作的不同,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

由于在开发过程中,pull 操作和 rebase 操作都是用来合并分支的,所以我就常常分不清这两个操作具体有什么区别,所以才有了这篇博客来做个简单区分,具体细致差别还请移步到官方文档:Git - Reference (git-scm.com)

1)pull 操作明确来说,实际是分为了两步操作:fetch + merge

fetch:进行 pull 操作的时候,git 首先会将远程仓库中的所有远程分支的最新一次提交内容拉取到本地仓库中对于远程仓库的跟踪分支中,相当于进行一次更新。但是这次更新并不会进行远程分支和本地分支的合并。

本地仓库中对于远程仓库的跟踪分支,简称为远程跟踪分支。远程跟踪分支是远程分支的本地副本,它们以 远程仓库(一般都为 origin ) / 远程分支名 的形式存在。fetch 会更新这些远程跟踪分支,使其与远程仓库中的分支同步。

merge:紧接着,会将当前的工作分支和已经建立了联系的对应的远程分支进行一次合并。又或者在 pull 操作的后续选项中指定了分支名,也会将指定的远程分支和当前本地的工作分支进行合并。

根据官方文档给出的示例,我们就能看出 pull 操作在 git 历史提交记录长什么样:

假设第二行中的 master 分支是我们当前本地的 master,提交历史为:D-E-F-G 。且本地的 master 分支最新一次与远程分支进行同步的节点为 E 。

第一行为远程仓库中的远程 master 分支,提交历史为:A-B-C

此时我们进行 pull 操作,就相当于将远程分支中的最新一次提交 C 同步到本地分支:

H 节点就为 pull 操作的第二步 merge 操作所产生的一次提交。可以看到,进行 pull 操作,由于默认第二步操作是使用了 merge 操作,因此会保留完整的提交记录。

2)rebase 操作称为变基操作,之所以叫做变基,是因为该操作改变了" 基础 ",实际作用就是改变提交的原本(" 基 ")位置。

还是借助官方文档给出的例子来进行解释:

假设新增本地有两个分支,master 和 topic ,现在在 topic 分支上进行 rebase master 的操作

此时 git 相当于会将 topic 分支的所有提交记录进行摘除,然后安接到 master 分支的最新一次分支,就相当于原本是基于 master 分支 E 节点所进行修改的 topic 上的所有记录,现在变成了基于 master 分支上的最新一次提交进行的修改似的:

可以看到,rebase 操作会将提交历史变得更加简洁整齐,呈线性的提交记录,不会出现明显的合并痕迹。

因此,其实 pull 操作和 rebase 之间并没有直接关联,真正关联的是 merge 操作和 rebase 操作。

二者所呈现的提交历史是不同的,具体需要哪个操作就需要看实际场景:

如果需要保持整齐的提交历史,那么就选择 rebase 操作;

如果想要保留完整的提交历史,那么就选择 merge 操作。

在 pull 操作中,默认第二步是使用 merge 操作,但是我们也可以指定使用 rebase 操作来合并分支,通过设置 git config --global pull.rebase true 来配置 rebase 选项来实现。

这篇关于Git 中 pull 操作和 rebase 操作的不同的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1089221

相关文章

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

Linux链表操作方式

《Linux链表操作方式》:本文主要介绍Linux链表操作方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、链表基础概念与内核链表优势二、内核链表结构与宏解析三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势六、典型应用场景七、调试技巧与

Java Multimap实现类与操作的具体示例

《JavaMultimap实现类与操作的具体示例》Multimap出现在Google的Guava库中,它为Java提供了更加灵活的集合操作,:本文主要介绍JavaMultimap实现类与操作的... 目录一、Multimap 概述Multimap 主要特点:二、Multimap 实现类1. ListMult

git stash命令基本用法详解

《gitstash命令基本用法详解》gitstash是Git中一个非常有用的命令,它可以临时保存当前工作区的修改,让你可以切换到其他分支或者处理其他任务,而不需要提交这些还未完成的修改,这篇文章主要... 目录一、基本用法1. 保存当前修改(包括暂存区和工作区的内容)2. 查看保存了哪些 stash3. 恢

Python中文件读取操作漏洞深度解析与防护指南

《Python中文件读取操作漏洞深度解析与防护指南》在Web应用开发中,文件操作是最基础也最危险的功能之一,这篇文章将全面剖析Python环境中常见的文件读取漏洞类型,成因及防护方案,感兴趣的小伙伴可... 目录引言一、静态资源处理中的路径穿越漏洞1.1 典型漏洞场景1.2 os.path.join()的陷

Python使用Code2flow将代码转化为流程图的操作教程

《Python使用Code2flow将代码转化为流程图的操作教程》Code2flow是一款开源工具,能够将代码自动转换为流程图,该工具对于代码审查、调试和理解大型代码库非常有用,在这篇博客中,我们将深... 目录引言1nVflRA、为什么选择 Code2flow?2、安装 Code2flow3、基本功能演示

Python中OpenCV与Matplotlib的图像操作入门指南

《Python中OpenCV与Matplotlib的图像操作入门指南》:本文主要介绍Python中OpenCV与Matplotlib的图像操作指南,本文通过实例代码给大家介绍的非常详细,对大家的学... 目录一、环境准备二、图像的基本操作1. 图像读取、显示与保存 使用OpenCV操作2. 像素级操作3.

python操作redis基础

《python操作redis基础》Redis(RemoteDictionaryServer)是一个开源的、基于内存的键值对(Key-Value)存储系统,它通常用作数据库、缓存和消息代理,这篇文章... 目录1. Redis 简介2. 前提条件3. 安装 python Redis 客户端库4. 连接到 Re

Java Stream.reduce()方法操作实际案例讲解

《JavaStream.reduce()方法操作实际案例讲解》reduce是JavaStreamAPI中的一个核心操作,用于将流中的元素组合起来产生单个结果,:本文主要介绍JavaStream.... 目录一、reduce的基本概念1. 什么是reduce操作2. reduce方法的三种形式二、reduce

MySQL表空间结构详解表空间到段页操作

《MySQL表空间结构详解表空间到段页操作》在MySQL架构和存储引擎专题中介绍了使用不同存储引擎创建表时生成的表空间数据文件,在本章节主要介绍使用InnoDB存储引擎创建表时生成的表空间数据文件,对... 目录️‍一、什么是表空间结构1.1 表空间与表空间文件的关系是什么?️‍二、用户数据在表空间中是怎么