合并分支往往不是一帆风顺的
我们新建一个分支,开始这次的学习
新建分支
创建并切换到feature1
git checkout -b feature1
修改文件
修改readme.txt
最后一行,添加一句
Creating a new branch is quick AND simple.
在feature1
分支上提交:
git add readme.txt
git commit -m "AND simple"
切换到master
分支
git checkout master
这里Git提醒我们当前master
分支比远程的master
分支要超前一个提交
在master
分支上把readme.txt
文件的最后一行改为
Creating a new branch is quick & simple.
提交
git add readme.txt
git commit -m "& simple"
现在,master
分支和feature1
分支分别都有了新的提交,就像下图
冲突
这种情况下,Git无法执行“快速合并”,只能试图把各自的修改合并起来,但这种合并就可能会有冲突,我们试试看:
git merge feature1
果然冲突了
git告诉我们readme.txt
文件存在冲突,必须手动解决后再提交。
git status
也可以告诉我们冲突文件的情况
我们可以直接查看readme.txt
的内容
Git用<<<<<<<
,=======
,>>>>>>>
标记出不同分支的内容,我们修改如下后保存:
Creating a new branch is quick and simple.
再提交
git add readme.txt
git commit -m "conflict fixed"
现在,master
分支和feature1
分支变成了下图所示:
用带参数的git log
也可以看到分支的合并情况:
git log --graph --pretty=oneline --abbrev-commit
最后删除feature1
git branch -d feature1
总结
当Git无法自动合并分支时,就必须首先解决冲突。解决冲突后,再提交,合并完成。
解决冲突就是把Git合并失败的文件手动编辑为我们希望的内容,再提交。
用git log --graph
命令可以看到分支合并图。