工作的时候遇到的git版本冲突与合并问题

问题的本质在于对Git对象模型引用系统的理解深度。遇到git问题的时候,不要慌张,什么问题都是可以解决的,只是还没用习惯,然后下面是git的几个区域以及代码在之间的流动过程示意图。

接下里就分享一下我在工作中遇到的实际的git问题以及解决方案:

1、release分支合错子分支了,还没push到远程仓库,怎么办?

描述:比如要发版合代码了,本来是要A分支合到release分支上了,结果把B分支合上面了

操作:git merge

分析:当我们merge之后,A分支的代码已经全部到了release分支的本地仓库中,只要还没push就问题不大,因为还只是在你自己的电脑上
解决方案 :直接删掉本地(Local)的release分支

然后fetch远程(remote)仓库(不是必要操作)

再check out release分支

就把远程仓库还没有污染的代码拉到了本地,本地已经污染的就直接被删除了,然后再正常把B分支的代码合过来,再push即可

2、release分支合错子分支了,已经push到远程仓库,怎么办?

描述:比如要发版合代码了,本来是要A分支合到release分支上了,结果把B分支合上面了,而且已经推送到远程仓库上去了

操作:git merge + git push

分析:当push之后,错的代码已经全都进远程仓库了,如果此时别人来拉的话就会把污染的代码全拉走,但是也不要慌,有解决方法
解决方案 :首先找到合B分支之前的那条记录,然后reset

选择Hard模式

然后再git push -f 强制推送,即可把release分支恢复到干净的版本了

3、在错误的分支上提交了代码

描述:比如需要在A分支上改一个bug,但是改到B分支了,并且暂存或者提交了

操作:git commit / git push

分析:这边推荐使用cherry pick实现不同分支之间的改动平移
解决方案 :切换到A分支,然后在git log中找到B分支暂存/提交的那条(多条)记录,然后直接cherry pick

在A分支直接push即可,然后回到B分支进行revert、push即可完成

先暂时记录到这,后面遇到类似的问题依旧持续更新

相关推荐
在下小孙14 小时前
Git与SVN常用指令
git·svn
H Journey1 天前
Git 教程
git
蜜汁小强1 天前
macOS 上的git代理配置在哪里
git·macos·代理模式·proxy模式
钟佩颖2 天前
Git .
git
Zhongyi_Li2 天前
git merge的一些记录
git
沛沛老爹2 天前
Web开发者转型AI:Agent Skills版本控制与管理实战——从Git到AI技能仓库
java·前端·人工智能·git·架构·rag
子琦啊2 天前
极速移除 Git 历史中的大文件,告别 git filter-branch太慢的问题
git
儒雅的晴天2 天前
git笔记
笔记·git
Ama_tor2 天前
git bash|下载、安装与配置(Windows11)
git
惜__缘2 天前
Git项目迁移的坑点
git