在 8.Git分支-分支的创建与合并-01 主要通过一个例子介绍了分支的新建,以及在工作中,git分支的新建切换以及使用,这里主要介绍分支的合并。这里的例子和8.Git分支-分支的创建与合并-01 的例子是连在一起的。

1.分支合并(没有冲突)

  分支合并主要使用:git merge <branch-name>

  接上一篇的例子:

  1.现在你关于defect #53的开发也已经完成了,现在branch的情况如下图所示。

9.Git分支-分支的创建与合并-02-LMLPHP

  2.你只需要运行下面两条命令,就能够将你在iss53上面的代码合并到master分支上了。

   git checkout master

   git merge iss53  

  合并之后的分支情况如下图所示。在执行git merge命令的时候,Git会将master分支和iss53分支所指的快照(C4,C5)以及它们的公共祖先(C2)做一个简单的三方合并。Git会自行选择最优的祖先作为合并的基础,这是与更加古老的CVS以及SVN(1.5版本以下)的一个很大的区别,这些系统中需要用户自己指定最佳的合并基础。

9.Git分支-分支的创建与合并-02-LMLPHP

  同样在合并完成之后,可以使用 git branch -d iss53 删除分支。

2.有冲突时候的合并

  合并分支有时候没有这么的顺利,有时候会存在冲突。

  冲突产生的情况:在两个不同的分支中,对同一个文件的同一个部分进行了修改,就会产生冲突。

  例如:上述例子中,如果你在hotfix和iss53分支中都对index.html的同一处位置进行了修改,那么在合并iss53到master分支的时候就会产生冲突,这时候你需要手动的去解决冲突,然后将index.html标记为冲突已解决,最后进行提交。

  出现冲突的文件会出现一些如下图所示的标记:

  其中在 ======= 的上半部分是HEAD所指向的master分支的内容,在 ======= 的下半部分是iss53分支的内容。你需要自己手动去选择保留 ======= 的上半部分或者下半部分,或者都保留。同时你也需要删除<<<<<<< HEAD:index.html       =======        >>>>>>> iss53:index.html 这些特殊标记。

<<<<<<< HEAD:index.html
<div id="footer">contact : [email protected]</div>
=======
<div id="footer">
please contact us at [email protected]
</div>
>>>>>>> iss53:index.html

  当你自己手动解决了所有的冲突之后,你需要运行 git add <filename> 来将每一个存在冲突的文件标记为冲突已解决的状态,并且暂存这些文件。通常你还需要运行 git status 来确认所有的冲突是否都已经解决了。

  最后你可以运行 git commit 来完成合并提交。在提交信息中,通常比较专业的做法是提供详细的信息来描述你是怎么解决这次冲突的,你的理由是什么。好像有个模板可以套用,用的时候可以自行百度。

05-06 22:27