图解 | git rebase使用笔记

图解 | git rebase使用笔记

大家好,又见面了,我是全栈君。

一、基本


git rebase用于把一个分支的修改合并到当前分支。
假设你现在基于远程分支”origin”,创建一个叫”mywork”的分支。

$ git checkout -b mywork origin
假设远程分支”origin”已经有了2个提交,如图

图解 | git rebase使用笔记

图1

现在我们在这个分支做一些修改,然后生成两个提交(commit).

$ 修改文件
$ git commit
$ 修改文件
$ git commit

但是与此同时,有些人也在”origin”分支上做了一些修改并且做了提交了. 这就意味着”origin”和”mywork”这两个分支各自”前进”了,它们之间”分叉”了

图解 | git rebase使用笔记

图2

在这里,你可以用”pull”命令把”origin”分支上的修改拉下来并且和你的修改合并;结果看起来就像一个新的”合并的提交”(merge commit):

图解 | git rebase使用笔记

图3

但是,如果你想让”mywork”分支历史看起来像没有经过任何合并一样,你也许可以用 git rebase:

$ git checkout mywork
$ git rebase origin

这些命令会把你的”mywork”分支里的每个提交(commit)取消掉,并且把它们临时 保存为补丁(patch)(这些补丁放到”.git/rebase”目录中),然后把”mywork”分支更新 为最新的”origin”分支,最后把保存的这些补丁应用到”mywork”分支上。

图解 | git rebase使用笔记

图解 | git rebase使用笔记

图4

当’mywork’分支更新之后,它会指向这些新创建的提交(commit),而那些老的提交会被丢弃。如果运行垃圾收集命令(pruning garbage collection), 这些被丢弃的提交就会删除. (请查看 git gc)

图解 | git rebase使用笔记

图5

二、解决冲突


在rebase的过程中,也许会出现冲突(conflict). 在这种情况,Git会停止rebase并会让你去解决 冲突;在解决完冲突后,用”git-add”命令去更新这些内容的索引(index), 然后,你无需执行 git-commit,只要执行:

$ git rebase –continue
这样git会继续应用(apply)余下的补丁。
在任何时候,你可以用–abort参数来终止rebase的行动,并且”mywork” 分支会回到rebase开始前的状态。

$ git rebase –abort

三、git rebase和git merge的区别


现在我们可以看一下用合并(merge)和用rebase所产生的历史的区别:

图解 | git rebase使用笔记

图6

当我们使用Git log来参看commit时,其commit的顺序也有所不同。

假设C3提交于9:00AM,C5提交于10:00AM,C4提交于11:00AM,C6提交于12:00AM,

对于使用git merge来合并所看到的commit的顺序(从新到旧)是:C7 ,C6,C4,C5,C3,C2,C1

对于使用git rebase来合并所看到的commit的顺序(从新到旧)是:C7 ,C6‘,C5′,C4,C3,C2,C1

因为C6’提交只是C6提交的克隆,C5’提交只是C5提交的克隆,
从用户的角度看使用git rebase来合并后所看到的commit的顺序(从新到旧)是:C7 ,C6,C5,C4,C3,C2,C1

另外,我们在使用git pull命令的时候,可以使用–rebase参数,即git pull –rebase,这里表示把你的本地当前分支里的每个提交(commit)取消掉,并且把它们临时 保存为补丁(patch)(这些补丁放到”.git/rebase”目录中),然后把本地当前分支更新 为最新的”origin”分支,最后把保存的这些补丁应用到本地当前分支上。

使用方式:
$ git pull –rebase <远程主机名> <远程分支名>:<本地分支名>

图解 | git rebase使用笔记

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/111602.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • DRM数字加密技术入门

    DRM数字加密技术入门DRM 英文全称 DigitalRight 可以翻译为 内容数字版权加密保护技术 由于数字化信息的特点决定了必须有另一种独特的技术 来加强保护这些数字化的音视频节目内容的版权 该技术就是数字权限管理技术 DRM digitalright DRM 技术的工作原理是 首先建立数字节目授权中心 编码压缩后的数字节目内容 可以

    2025年11月16日
    4
  • postman安装使用教程_postman怎么使用

    postman安装使用教程_postman怎么使用目录第一部分:基础篇postman1.安装postman进入postman官网,如果是mac系统可以直接点击macapp安装第二部分:进阶篇1.使用自带的脚本对接口进行测试第一部分:基础篇postman1.安装postman进入postman官网,如果是mac系统可以直接点击macapp安装如果是windows的话,需要在windows下安装chrome浏览器,然后在地址栏输入chrome://extensions,勾选开发者模式然后将下载的postman插件解压,浏览器点击加

    2025年12月10日
    6
  • 【网络】子网划分题目解析[通俗易懂]

    【网络】子网划分题目解析[通俗易懂]【网络】子网划分题目解题过程步骤一:划分分公司子网步骤二:划分分公司部门子网题目某集团公司,全国共设立12家分公司,每家分公司有4个部分组成,现在公司需要组建企业内部网络,总公司申请一个IP:172.16.0.0/16,试为该集团公司IP分配做出合理规划解题过程步骤一:划分分公司子网“全国共设立12家分公司”根据这句话可以明白至少要划分12个分公司子网,就需要我们查找2n≥12,依题意得24=16≥12,因此网络位向主机位借取4位,也就是用原有的16+4=20,那么子网掩码就是/20即2

    2022年6月27日
    28
  • OpenCms创建网站的过程示意图——专用OpenCms人们刚开始学习

    OpenCms创建网站的过程示意图——专用OpenCms人们刚开始学习

    2021年12月17日
    44
  • RadioButton实现多选一

    RadioButton实现多选一

    2022年3月5日
    40
  • spring aop实例讲解_java swing 教程

    spring aop实例讲解_java swing 教程1.SpringAOP是什么?AspectOrientedProgramming:面向切面编程什么时候会出现面向切面编程的需求?按照软件重构的思想,如果多个类中出现重复的代码,就应该考虑定义一个共同的抽象类,将这些共同的代码提取到抽象类中,比如Teacher,Student都有username,那么就可以把username及相关的get、set方法抽取到SysUser中,这种情况,我们称…

    2022年8月11日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号