工作的时候遇到的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即可完成

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

相关推荐
lifewange3 小时前
常用的Git命令有哪些?
git
无限进步_3 小时前
【C++】电话号码的字母组合:从有限处理到通用解法
开发语言·c++·ide·windows·git·github·visual studio
C++ 老炮儿的技术栈4 小时前
GCC编译时无法向/tmp 目录写入临时汇编文件,因为设备空间不足,解决
linux·运维·开发语言·汇编·c++·git·qt
英俊潇洒美少年4 小时前
Git 常用命令速查表(前端开发专属版)
git
华科大胡子8 小时前
Git二分法定位Bug
git
m0_579146659 小时前
Git暂存区操作与版本回退
git
三毛的二哥10 小时前
git:git worktree多任务并行开发
git
Yiyi_Coding10 小时前
Git 版本管理重要撤回操作
git
a里啊里啊10 小时前
Git常问面试题
git
达子66610 小时前
Git中文文件名乱码显示SHA-1 哈希值
git·算法·哈希算法