IDEA中Git冲突的产生及解决方法

时间:2024-03-24 07:08:24

1.1 冲突产生的原因

冲突产生的根本原因是:两个人修改了同一个文件的同一块区域,在前者已经提交代码到远程仓库的情况下,后者修改代码前没有使用pull命令更新代码,而是修改完代码后再使用pull命令,这时就会产生冲突。这也是最常见的冲突,下面介绍解决冲突的办法也主要针对这种冲突。

1.2 预防冲突的发生

在修改代码前,使用pull命令更新代码,能够保证在开始修改代码前本地的代码与远程仓库中的版本一致,这样能够大大降低冲突发生的概率,如下图所示。

IDEA中Git冲突的产生及解决方法

1.3 冲突的解决

1、只有冲突文件

当使用pull命令或者push命令被拒绝(如图1所示)merge分支后,要提交的文件出现如图2所示情况则是发生了冲突,并弹出如图3所示的窗口,双击冲突文件,出现如图4所示窗口,在该窗口中可以选择最终要使用的代码。

 IDEA中Git冲突的产生及解决方法

图1 push被拒绝

 IDEA中Git冲突的产生及解决方法

图2 产生冲突

 IDEA中Git冲突的产生及解决方法

图3 产生冲突时的弹窗

在该窗口中可以通过点击>><<或者下面的按钮选择最终要使用的代码。

IDEA中Git冲突的产生及解决方法

图11 Merge Revisions窗口

确定最终使用的代码后,如果使用的是本地的代码,可以直接push到远程仓库,否则需要commit到本地仓库,然后提交到远程仓库。

2、有冲突文件,也有未更新的文件

如下图所示为有冲突文件也有未更新文件的情况,test.jsp为出现冲突的文件(红色字体),index.jsp为修改代码前未更新的文件(蓝色字体),并且使用pull或者merge命令后没有出现冲突。

IDEA中Git冲突的产生及解决方法

此时工程中index.jsp文件与远程仓库中的版本一致,但是与本地仓库中的版本不一致,因此需要将index.jsp和修改后的test.jsp文件commit到本地仓库中,然后只需要将test.jsp文件push到远程仓库即可,如下图所示,只有test.jsp需要提交到远程仓库。

IDEA中Git冲突的产生及解决方法