git完全教程:012—Git解决分支冲突

目录

  • 新建分支
  • 修改文件
  • 冲突
  • 总结

合并分支往往不是一帆风顺的
我们新建一个分支,开始这次的学习

新建分支

创建并切换到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完全教程:012—Git解决分支冲突_第1张图片
这里Git提醒我们当前master分支比远程的master分支要超前一个提交

master分支上把readme.txt文件的最后一行改为

Creating a new branch is quick & simple.

提交

git add readme.txt
git commit -m "& simple"

git完全教程:012—Git解决分支冲突_第2张图片

现在,master分支和feature1分支分别都有了新的提交,就像下图
git完全教程:012—Git解决分支冲突_第3张图片

冲突

这种情况下,Git无法执行“快速合并”,只能试图把各自的修改合并起来,但这种合并就可能会有冲突,我们试试看:

git merge feature1

在这里插入图片描述

果然冲突了
git告诉我们readme.txt文件存在冲突,必须手动解决后再提交。
git status也可以告诉我们冲突文件的情况

git完全教程:012—Git解决分支冲突_第4张图片
我们可以直接查看readme.txt的内容
git完全教程:012—Git解决分支冲突_第5张图片
Git用<<<<<<<=======>>>>>>>标记出不同分支的内容,我们修改如下后保存:

Creating a new branch is quick and simple.

在这里插入图片描述

再提交

git add readme.txt
git commit -m "conflict fixed"

在这里插入图片描述

现在,master分支和feature1分支变成了下图所示:

git完全教程:012—Git解决分支冲突_第6张图片

用带参数的git log也可以看到分支的合并情况:

git log --graph --pretty=oneline --abbrev-commit

git完全教程:012—Git解决分支冲突_第7张图片
最后删除feature1

git branch -d feature1
在这里插入图片描述

总结

当Git无法自动合并分支时,就必须首先解决冲突。解决冲突后,再提交,合并完成。

解决冲突就是把Git合并失败的文件手动编辑为我们希望的内容,再提交。

git log --graph命令可以看到分支合并图。

你可能感兴趣的:(Git完全教程,git,github)