当前位置:   article > 正文

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

merge代码消失

现象

最近遇到了,很坑的事情!!!
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中。

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小舞很执着/article/detail/930946
推荐阅读
相关标签
  

闽ICP备14008679号