相关推荐recommended
git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支
作者:mmseoamin日期:2024-02-06

GIT | 分支

文章目录

  • GIT | 分支
    • 创建分支
    • 合并分支
    • 删除分支
    • 合并冲突
    • 分支管理策略
    • bug分支
    • 强制删除分支

      创建分支

      查看当前本地仓库中有哪些分支

      git branch
      

      HEAD所指向的分支就是当前正在工作的分支

      cat .git/HEAD
      

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第1张

      创建一个分支

      git branch dev
      

      创建好了,但是目前还是指向master

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第2张

      用tree命令也可以看到已经创建分支成功了

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第3张

      创建出来的分支,和主分支的最新记录是一样的

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第4张

      切换分支就是让HEAD指向我们的dev分支

      git checkout dev
      

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第5张

      我们在dev分支上堆ReadMe文件进行了修改

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第6张

      再进行提交

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第7张

      这个时候再切换回master分支

      查看文件

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第8张

      可以看到刚刚新加的那行文件不见了~~

      那我们再切换回dev分支上看

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第9张

      发现那行新加的还在

      我们查看这里发现已经变了

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第10张

      我们查看记录

      dev上是最新的记录,master分支第二

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第11张

      我们最终的效果是在master分支上看到我们的效果,我们怎么操作呢?

      合并分支

      这就要我们合并分支,在合并分支之前就需要先切换到我们master分支上

      git merge dev
      

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第12张

      删除分支

      只能在其他的分支上删除本分支

      git branch -d dev
      

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第13张

      合并冲突

      在合并分支的时候,我们在master分支上已经修改了文件,而我在dev分支上也修改了文件,然后合并的时候就会出现报错,我们来演示一下

      快速创建分支并且进入分支

      git checkout -b dev1
      

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第14张

      我们将原来的aaa改成了bbb

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第15张

      然后提交上去

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第16张

      我们切换到master分支上查看一下文件内容,发现还是aaa,因为还没有合并

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第17张

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第18张

      接下来我们就继续将这个aaa改成ccc,然后再进行合并分支

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第19张

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第20张

      这个时候再进行合并,会提示合并冲突

      git merge dev1
      

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第21张

      我们打开ReadMe文件查看一下

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第22张

      这个时候就要手动选择要保留哪些代码

      假设我们就保留这些代码

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第23张

      然后再进行提交

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第24张

      查看是否是最新提交

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第25张

      可视化的查看方法

      git log --graph --abbrev-commit
      

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第26张

      分支管理策略

      不使用Fast forward模式

      创建一个新分支

      git checkout -b dev2
      

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第27张

      修改ReadMe文件,并提交

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第28张

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第29张

      切换回master分支后进行合并

      不使用Fast forward模式

      git merge --no-ff -m "merge with no-ff" dev2
      

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第30张

      bug分支

      假如我们现在正在 dev2 分支上进行开发,开发到一半,突然发现master 分支上面有 bug,需要

      解决。在Git中,每个 bug 都可以通过一个新的临时分支来修复,修复后,合并分支,然后将临时分支删除

      git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第31张

      • 这个时候主分支出现了一个bug,这个时候就要i切换到master分支

        git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第32张

        那我们不想这样,我们可以这样做

        将工作区的内容进行保存

        git stash
        

        git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第33张

        修复完bug后,我们就需要进行重新回到dev2分支继续开发

        git stash pop
        

        git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第34张

        现在我们到了dev2分支上了,我们继续开发

        git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第35张

        然后提交,在dev分支上进行了新的提交

        git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第36张

        这个时候就需要合并了,但是合并的时候就会出现冲突,刚刚master修改了bug了,这次又要进行合并分支,我们需要解决错误

        我们需要不在master上合并分支,在dev合并master主分支,把问题再本地上解决了再做下一步

        我们在dev2分支上进行合并

        git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第37张

        手动修改冲突

        git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第38张

        然后就可以合并了~~

        git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第39张

        最后不要忘了,把刚刚的临时分支和开发分支删除~~

        git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,在这里插入图片描述,第40张

        强制删除分支

        如果在开发中如果在一个分支上已经开发,对代码进行提交了,这个时候用传统的方法进行删除是不能删除的,我们需要用到-D来进行删除~~

        git branch -D dev3
        
        • 分支在实际中有什么用呢?假设你准备开发一个新功能,但是需要两周才能完成,第一周你写了50%的代码,如果立刻提交,由于代码还没写完,不完整的代码库会导致别人不能干活了。如果等代码全部写完再一次提交,又存在丢失每天进度的巨大风险。
        • 现在有了分支,就不用怕了。你创建了一个属于你自己的分支,别人看不到,还继续在原来的分支上正常工作,而你在自己的分支上干活,想提交就提交,直到开发完毕后,再一次性合并到原来的支上,这样,既安全,又不影响别人工作。
        • 并且 Git 无论创建、切换和删除分支,Git在1秒钟之内就能完成!无论你的版本库是1个文件还是1万个文件。