Git学习笔记四(创建和合并分支) - Go语言中文社区

Git学习笔记四(创建和合并分支)


Git学习笔记四

创建与合并分支

  • 在Git中,主分支是master分支,一开始的时候,master分支是一条线,Git用master指向最新的提交,再用HEAD指向master,就能确定当前分支,以及当前分支的提交点,每次提交,master分支都会向前移动。如图
    这里写图片描述
  • 当我们创建新的分支,例如dev时,Git新建了一个指针叫dev,指向master相同的点,再把HEAD指向dev,就表示当前分支在dev上,如图
    这里写图片描述
  • 我的理解就是每一个分支的名字都相当于一个指针,指向这条分支线最新提交的节点,而HEAD指针是指向当前工作分支的指针。
  • 倘若我们在dev上的工作完成了,就可以把dev合并到master上。在简单情况下,就是直接把master指向dev的当前提交,就完成了合并。

  • 创建新分支可以用git branch name,切换分支可以用git checkout name,也可以用命令同时完成这两个功能(创建并切换)。如下

    $ git checkout -b dev 
    Switched to a new branch 'dev'

  • 这个等效于
    $ git branch dev 
    $ git checkout dev
    Switched to branch 'dev'
  • 查看分支情况用git branch,前面加*表示当前分支,如

    $ git branch 
    * dev
    master

  • 现在git addgit commit就是在dev分支操作了。

  • 删除分支用git branch -d name,如
    $ git branch -d dev 
    Deleted branch dev (was fec145a).
  • 将分支合并到主分支上,在主分支下用git merge name,如

    $ git merge dev 
    Updating d17efd8..fec145a
    Fast-forward
    readme.txt | 1 +
    1 file changed, 1 insertion(+)

  • 当合并产生了冲突,比如master和dev分别有新的提交,如图
    这里写图片描述

  • git status可以告诉我们冲突的文件,git log --graph可以看到分支合并图。
  • 总而言之,当Git无法自动合并分支时,就必须首先解决冲突,解决冲突后(在文本文件内根据提示将内容修改至和HEAD指向内容相同),再提交,合并完成。

本文是本人学习廖雪峰git教程过程中的学习记录,详细教程可以参见廖雪峰Git教程

版权声明:本文来源CSDN,感谢博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/peisir/article/details/77073813
站方申明:本站部分内容来自社区用户分享,若涉及侵权,请联系站方删除。
  • 发表于 2020-04-18 18:25:35
  • 阅读 ( 1346 )
  • 分类:

0 条评论

请先 登录 后评论

官方社群

GO教程

猜你喜欢