Git分支合并冲突处理

冲突问题复现

        我们先复现一个冲突问题,具体做法如下:

(1)任意找个目录,在该目录下创建一个testmerge目录,进入目录执行git init,初始化一个仓库,如图:

Git分支合并冲突处理_第1张图片

(2)在testmerge目录下创建一个readme.md文件,并执行git add和git commit命令将文件提交到仓库的master分支,如图:

Git分支合并冲突处理_第2张图片

此时分支示意图如下:

Git分支合并冲突处理_第3张图片

 (3)创建并切换到分支hotfix,如图:

此时分支示意图如下:

Git分支合并冲突处理_第4张图片

(4)在分支hotfix下,向文件readme.md中随便添加一行内容,例如:

# hotfix

,保存退出,并提交添加内容后的文件,如图:

此时分支示意图如下:

Git分支合并冲突处理_第5张图片

(5)进入master分支下,此时readme.md一定是空文件,因为在master分支下尚未对该文件做任何操作,现在在文件中添加如下一行内容:

# hotfix

,保存退出,并提交文件,如图:

此时分支示意图如下:

Git分支合并冲突处理_第6张图片

(6)此时如果在master分支下执行git merge合并操作,就会出现如下冲突问题:

Git不会自动合并,它会暂停整个过程,等待处理。冲突出现的原因就是在master和hotfix分支下,对同一个文件进行了修改。

 

解决

(1)git status可以查看哪些文件有冲突没有合并,如图:

Git分支合并冲突处理_第7张图片

(2)打开readme.md文件,发现文件已经变成如下情况:

Git分支合并冲突处理_第8张图片

其中=======的上半部分对应的是master分支内容(HEAD指向当前分支,因为合并命令是在master分支中执行的),下半部分对应的是hotfix分支内容,现在就可以选择任何一个版本或者合并两个版本作为最终版本来解决冲突了。例如内容变为:

# master
# hotfix

 

(3)冲突全部解决完后,在master分支下执行git add和git commit就可以完成最终版本提交,如图:

Git分支合并冲突处理_第9张图片

此时分支示意图如下:

Git分支合并冲突处理_第10张图片

 

 

你可能感兴趣的:(Git/GitHub)