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

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

相关推荐
一只大袋鼠7 小时前
Git 进阶(二):分支管理、暂存栈、远程仓库与多人协作
java·开发语言·git
我叫张小白。14 小时前
Git 分支管理与团队协作
git
DogDaoDao15 小时前
Windows 下 Git 报错:`touch` 无法识别 —— 原因分析与 7 种解决方案(从入门到精通)
windows·git·程序员·npm·powershell·cmd·touch
caicai_xiaobai16 小时前
Ubuntu上Git安装步骤
linux·git·ubuntu
come1123417 小时前
git 区分是 Git 分支还是 worktree 路径名
git
憧憬成为java架构高手的小白18 小时前
git多人工作之个人规范使用【ai+个人理解】
git
CVer儿18 小时前
git简单操作
git
Andya_net18 小时前
Git | Git 核心命令深入解析:从原理到实战
大数据·git·elasticsearch
wh_xia_jun19 小时前
给小白的 Maven 命令行执行测试 完整指南
git·maven·intellij-idea
专业白嫖怪19 小时前
H3C UniServer R4950 G5 服务器压测实战:13根内存条24小时压力测试全流程
git