多人协作开发git merge合并功能出现冲突时解决思路

目录

问题背景描述

解决思路

解决详细步骤

经验适用场景


问题背景描述

现在有一个本地分支A,远端其中两个分支B、C,其中C为主分支,A和B目前版本是一致的,且都比较新,C的版本比较落后,现在需要从分支B合并到C。但是远程个人分支B向远程目标分支C进行merge时出现冲突。

解决思路

解决思路主要为:先将远端目标分支C向本地源分支A合并,合并时出现冲突,然后在本地文件中进行冲突解决。解决好后再向远端B推送,然后再次由B向C发起合并请求就没问题了。

解决详细步骤

1.先在本地git fetch,以便获得最新远端分支C的最新版本

2.然后在本地将最新远端分支C合并到本地分支A, git merge origin/C A

上面这条合并命令后,会出现提示信息,哪些文件合并顺利的,哪些出现了冲突

3.然后针对出现冲突的那些文件,在ide中查看,每个有冲突的部分大概像下面这样

bash 复制代码
<<<<<<< HEAD
你的改变
=======
他人的改变
>>>>>>> 分支名

4.你需要手动解决这些冲突:手动编辑这些区域,选择你想要保留的更改,并删除冲突标记符号(<<<<<<<, =======, >>>>>>>)。

5.保存文件:将解决冲突后的文件保存。保存可以用git status查看状态。

6.提交:执行git add将解决后的文件标记为已解决冲突,然后可以继续使用git commit来提交。

7.推送:将本地分支A推送到远程分支B,必要时强制推送

8.再次合并:将远程分支B合并到远程分支C

经验适用场景

多人协同开发时,比如每个人开发一个功能分支,开发完成后,每个人都会向主分支发起合并请求(merge request),对每个人的合并请求处理是有先后顺序的,合并第一个人的功能时可能不会出现冲突,但第二个人就就可能出现冲突,这时就需要对冲突给予解决,本文提供一定参考思路,实际工作时可能需要更加灵活处理。



end

相关推荐
wdfk_prog41 分钟前
Git实战指南:如何从另一个分支同步文件时完整保留Commit提交历史
git
In_life 在生活1 小时前
GIT stash 命令的使用
git
SunkingYang2 小时前
如何通过命令和TortoiseGit工具来撤销最后一次提交,包含提交到缓存区,提交到远程仓库
git·tortoisegit·工作区·暂存区·远程仓库·撤销·最后一次提交
南山nash7 小时前
git从入门到熟练
git
夜流冰10 小时前
Git - GitForWindows
git
一个很帅的帅哥11 小时前
部署chat-vue
大数据·git·elasticsearch
芒鸽11 小时前
鸿蒙PC使用ffmpeg+electron实现视频中音频的提取
git
SunkingYang12 小时前
使用TortoiseGit工具推送(push)时,忘了先拉取(Pull),提示冲突,后续怎么处理冲突?
git·tortoisegit·pull·push·推送·冲突·拉取
BestOrNothing_201512 小时前
Git 团队开发冲突合并全流程:本地是否改动 + 远端是否更新,如何正确同步并合并(同分支/不同分支下的几种场景)
git·分支管理·git pull·git merge·分支冲突·git协作·git fetch
zzlyyds13 小时前
工作的时候遇到的git版本冲突与合并问题
git