Git 解决分支冲突

一、前言

一直习惯于 add commit push 的三步走,偶然间看到了一个评论说在 push 之前还有一个 pull,小小的疑问就埋在了我的心里。于是我就先了解了 pull 的工作原理,就是先拉取代码(fetch)再合并分支(merge)的过程,简而言之就是在本地进行项目编写时,他人也在其他地方进行项目编写并且提前进行了 push 操作,使得当前的云端文件比我克隆下来的文件版本更加新,那么进行合并就会因为冲突被拒绝(rejected)。因此才需要先更新项目(pull),再进行我的 push。那么问题来了,如果别人编写的内容与我编写的内容在源文件的同一个地方,那不就出问题了吗?!于是有了这篇文章

二、项目演示

我们通过 github 上的 Network 进行可视化讲解。假设现在我们有一个本地项目、github 空仓库、本地仓库提交记录,如下

github 空仓库

本地项目文件夹

本地仓库提交记录

第一次 push 后,我们查看 Network 效果如下:

第一次 push 后的 Network

已知 test.md 文件中内容现在是这样的

test.md 文件中内容

2.1 没有冲突时

现在我们在本地对 test.md 文件进行编辑,编辑后如下:

编辑后的 test.md 文件

然后在 github 上对该文件的 其他地方 进行编辑并 push,模拟 别人更早更新项目代码但是不冲突 的情况,如下:

模拟别人更早更新项目代码的情况

现在我们在本地进行提交操作,显然会报错,因为远程已经更新:

远程已经更新而被 rejected

现在我们需要进行合并,也就是执行 pull,再 push 即可,由于合并后会产生一个新的结点,因此会弹出 vim 界面让你编写 comment:

vim 界面

然后就成功 pull 了代码,之后再 push 就没问题了:

成功 push 了代码

成功 push 了代码

我们来看一下现在的 test.md 是什么样的:

无冲突合并后的结果

可以发现内容进行了合并,现在的 Network 图如下:

现在的 Network 图

2.2 有冲突时

为了更加直观的展示,我们在原有的基础上多增加几个正常结点,当前 Network 如下:

当前 Network 图

然后我们在本地对 test.md 文件进行编写:

第二次本地修改

然后在 github 上对该文件的 相同地方 进行编辑并 push,模拟 别人更早更新项目代码但是发生冲突 的情况,如下:

模拟别人更早更新项目代码但是发生冲突的情况

然后 add、commit,在视图 pull 进行合并时,出现了问题:

提示冲突同时分支名变成了 main|MERGING

提示我们修复冲突后再进行 commit,同时分支名变成了 main|MERGING 状态,本地试图 push 的代码也出现了变化,如下:

本地试图 push 的代码

我们也可以使用 git diffgit status 来查看冲突:

使用 git diff 或 git status 来查看冲突

其中,<<<<<<<======= 之间是 HEAD 的代码,========>>>>>>> 之间是 main 的代码,git 对冲突内容主动进行了错位,我方最新内容在上(也就是 HEAD 的代码),分支最新内容在下,确保不会再冲突。我们根据实际情况解决冲突内容,如下:

根据实际情况解决冲突内容后

然后我们重新 commit 并加上 -a 参数后,进行 push:

重新 commit 并加上 -a 参数后,进行 push

最终 test.md 内容如图:

最终 test.md 内容

最终 Network 如图:

最终 Network 图

三、总结

总的来说,就两句话

  • 当我的改动与最新项目的改动没有重叠时:pull 后就直接进行合并
  • 当我的改动与最新项目的改动有重叠时:pull 后解决冲突,然后执行下方命令即可
    • git commit -a -m '<comment>'
    • git push
  • 30
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Mr_Dwj

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

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

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

打赏作者

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

抵扣说明:

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

余额充值