Git-Automatic merge failed; fix conflicts and then commit the result. 解决

Git-Automatic merge failed; fix conflicts and then commit the result. 解决

文章目录

  • [1. 杂话](#1. 杂话)
  • [2. 问题](#2. 问题)
    • [2.1 先搞定版本A](#2.1 先搞定版本A)
    • [2.2 再搞定版本A+C](#2.2 再搞定版本A+C)
    • [2.3 搞定A+B版本](#2.3 搞定A+B版本)
    • [2.4 冲突](#2.4 冲突)
  • [3. 解决](#3. 解决)
    • [3.1 分析](#3.1 分析)
    • [3.2 解决](#3.2 解决)

1. 杂话

大伙儿应该都用过Git吧,具体是个啥东西我就不说了哈。之前我在用git merge的时候遇到了这个报错,我仔细思考了一下,这个问题如果不出意外的话,那么应该就是出现了冲突,也就是有多个分支的情况下,git merge的时候出现了冲突。那咱们来说说这个问题应该怎么解决。

2. 问题

这个问题到底是咋回事儿呢,我举个例子哈。比如说原本你的文件是版本A,比如说你在第一个分支做了修改B,但是同时呢,你又在第二个分支做了修改C。

那么现在呢,你的分支一是A+B,分支二是A+C。那么这个时候你想把A+B先给cmomit了,然后又commit了分支二的A+C。再然后,你使用git merge来合并两个分支。

也就是说,这个问题出现在两个分支同时对于一个文件做出了修改的时候。

咱们来举个例子说一下吧

2.1 先搞定版本A

首先,咱们弄个文件merge.txt,里面大概长这个样子:

bash 复制代码
AAAAAAAA
AAAAAAAA

2.2 再搞定版本A+C

现在,创建一个新的分支

bash 复制代码
$ git checkout -b new_branch

然后咱们在这里面把merge.txt文件改编成:

bash 复制代码
AAAAAAAA
CCCCCCCC

2.3 搞定A+B版本

接下来,切换回分支一,比如说是master吧:

bash 复制代码
$ git checkout master
$ echo "BBBBBBBB" >> merge.txt
$ git commit -am"A+B"

注意,这个时候在分支一里面文件的内容是

bash 复制代码
AAAAAAAA
AAAAAAAA
BBBBBBBB

2.4 冲突

接下来,在分支一上使用git merge就会出现这个报错。

3. 解决

3.1 分析

我们打开merge.txt,会看到文件里面的内容如下:

bash 复制代码
AAAAAAAA
<<<<<<< HEAD
AAAAAAAA
BBBBBBBB
=======
CCCCCCCC
>>>>>>> new_branch

其中多出来了三个标记

  • <<<<<<< HEAD
  • =======
  • >>>>>>> new_branch

这些记号的意思是这样的:

  • <<<<<<< HEAD和=======之间的是分支一修改的内容
  • >>>>>>> new_branch和=======是分支二修改的内容
  • 其他的是分支一和分支二一样的内容,或者说都没有修改的内容

3.2 解决

首先,我们需要编辑merge.txt文件,保留需要的内容,之后删掉上面的三个标记。之后在使用git add,git commit就可以了。

当然了,如果说不想合并了,也只需要使用

bash 复制代码
git merge --abort

就可以了。

Ref:

https://www.atlassian.com/git/tutorials/using-branches/merge-conflicts

https://blog.csdn.net/u010393510/article/details/127121169

相关推荐
@ZyuanZhang2 小时前
github使用记录
github
Kusunoki_D8 小时前
Git Bash 启动时 ssh-agent 多次尝试启动但失败
git·ssh·bash
Code_流苏9 小时前
如何使用Git参与GitHub开源项目:入门全流程
git·开源·github·开源项目·入门学习
初级代码游戏11 小时前
基于C++的IOT网关和平台1:github项目ctGateway
c++·物联网·github
我是哪吒12 小时前
分布式微服务系统架构第124集:架构
后端·面试·github
2501_9153743513 小时前
git 查看用户信息
git
掘金安东尼13 小时前
每天点开的 Omnissa Horizon Client,背后其实是一次完整的桌面重构
面试·github·远程工作
palomua20 小时前
Git Updates were rejected because the remote contains work that you do not
git
PPIO派欧云1 天前
PPIO X OWL:一键开启任务自动化的高效革命
运维·人工智能·自动化·github·api·教程·ppio派欧云