Git分支合并冲突处理

冲突问题复现

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

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

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

此时分支示意图如下:

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

此时分支示意图如下:

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

# hotfix

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

此时分支示意图如下:

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

# hotfix

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

此时分支示意图如下:

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

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

 

解决

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

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

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

# master
# hotfix

 

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

此时分支示意图如下:

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ErbaoLiu

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值