• 技术文章 >开发工具 >git

    git rebase是什么意思

    青灯夜游青灯夜游2021-12-29 17:04:36原创6167

    git rebase的意思为:重新定义分支的版本库状态;当执行rebase操作时,git会从两个分支的共同祖先开始提取待变基分支上的修改,然后将待变基分支指向基分支的最新提交,最后将刚才提取的修改应用到基分支的最新提交的后面。

    本教程操作环境:Windows7系统、Git2.30.0版、Dell G3电脑。

    git rebase,顾名思义,就是重新定义(re)起点(base)的作用,即重新定义分支的版本库状态。

    一、提交节点图解

    首先通过简单的提交节点图解感受一下rebase在干什么

    两个分支master和feature,其中feature是在提交点B处从master上拉出的分支

    master上有一个新提交M,feature上有两个新提交C和D

    在这里插入图片描述
    此时切换到feature分支上,执行如下命令,相当于是想要把master分支合并到feature分支

    git checkout feature
    git rebase master
    
    //这两条命令等价于git rebase master feature

    下图为变基后的提交节点图,解释一下其工作原理:

    在这里插入图片描述

    官方解释:当执行rebase操作时,git会从两个分支的共同祖先开始提取待变基分支上的修改,然后将待变基分支指向基分支的最新提交,最后将刚才提取的修改应用到基分支的最新提交的后面。

    结合例子解释:当在feature分支上执行git rebase master时,git会从master和featuer的共同祖先B开始提取feature分支上的修改,也就是C和D两个提交,先提取到。然后将feature分支指向master分支的最新提交上,也就是M。最后把提取的C和D接到M后面,但这个过程是删除原来的C和D,生成新的C’和D’,他们的提交内容一样,但commit id不同。feature自然最后也是指向D’。

    通俗解释(重要!):rebase,变基,可以直接理解为改变基底。feature分支是基于master分支的B拉出来的分支,feature的基底是B。而master在B之后有新的提交,就相当于此时要用master上新的提交来作为feature分支的新基底。实际操作为把B之后feature的提交存下来,然后删掉原来这些提交,再找到master的最新提交位置,把存下来的提交再接上去(新节点新commit id),如此feature分支的基底就相当于变成了M而不是原来的B了。

    其中还有一句解释也很直白,rebase 命令其实关键在于理解「基」,git rebase <基分支>,就是将基分支与当前分支的差异提交(分岔点之后)获取到,然后在「基分支」最新提交点后面将差异提交逐个再次提交,最后将当前分支的 HEAD 指针指向最新的提交点


    二、实际git提交示例

    按照上面的图解构造了提交记录,如下图所示:(ABM是master分支线,ABCD是feature分支线。这里画成了master变色分叉出来,这不影响理解,知道是表示两个分支两条线即可!)

    在这里插入图片描述
    此时,在feature分支上执行git rebase master

    变基完成以后,ABCD是原来的feature分支线,ABMC’D’是新的feature分支线,ABM是master分支线(没有变化)

    在这里插入图片描述


    三、推荐使用场景

    搞来搞去那么多,这其实是最重要的。不同公司,不同情况有不同使用场景,不过大部分情况推荐如下:

    推荐学习:《Git教程

    以上就是git rebase是什么意思的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:git rebase
    上一篇:git中gui是什么意思 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • myeclipse怎么安装git插件• git status中文乱码怎么办• linux 源码怎么安装git• git属于什么版本的控制系统• go语言项目是怎么配置Gitlab CI的• 悄悄分享怎么加速访问Github!(推荐)
    1/1

    PHP中文网