[git]2个分支合并,引起的代码部分丢失!!!

现象

最近遇到了,很坑的事情!!!
2个分支合并,引起的代码部分丢失

  1. 用户u1 commit a 提交到branch1
  2. 用户u1基于remote master拉取branch2
  3. 用户u1 cherry-pick a到branch2
  4. 用户u2 commit b 提交到branch1
  5. 用户u1 push branch2到remote branch2
  6. branch2对应的版本发布后,remote branch2自动合并代码到remote master
  7. 用户u1 pull remote master的代码到branch1
  8. 用户u2 pull remote branch1到本地,发现commit b的代码部分丢失。

原因

由于用户u1在步骤7之前没有先从远程branch1拉取代码到本地,您在步骤8中发现commit b的代码部分丢失是可以理解的。在用户u1将branch2推送到远程branch2后,远程branch2的代码合并到远程主分支remote master时,branch1和branch2之间的代码差异可能会导致commit b的代码部分被覆盖。因此,当用户u2在步骤8中从远程branch1拉取代码时,commit b的部分代码可能已经丢失。

解决方案

为了解决这个问题,建议用户u1在步骤7之前,应先拉取并合并远程branch1的代码到本地的branch1,以确保本地分支的代码与远程分支保持同步。这样,当远程branch2的代码合并到remote master时,commit b的代码部分不会被覆盖,仍然存在于本地branch1中。

另外,为了避免代码丢失,建议用户在进行分支合并之前,应保证自己的本地分支代码与远程分支代码同步,避免出现代码冲突和丢失的情况。

  • 8
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值